> For clean Markdown of any page, append .md to the page URL.
> For a complete documentation index, see https://docs.astropods.com/llms.txt.
> For AI client integration (Claude Code, Cursor, etc.), connect to the MCP server at https://docs.astropods.com/_mcp/server.

# Get pod logs

GET https://astropods.com/api/v1/deployments/{namespace}/logs

Returns the last N lines of logs from a pod in the deployment's namespace.

Reference: https://docs.astropods.com/api-reference/astro-ai-api/deployments/get-deployment-logs

## OpenAPI Specification

```yaml
openapi: 3.1.0
info:
  title: astro-api
  version: 1.0.0
paths:
  /deployments/{namespace}/logs:
    get:
      operationId: get-deployment-logs
      summary: Get pod logs
      description: >-
        Returns the last N lines of logs from a pod in the deployment's
        namespace.
      tags:
        - subpackage_deployments
      parameters:
        - name: namespace
          in: path
          description: Kubernetes namespace for the deployment
          required: true
          schema:
            type: string
        - name: account
          in: query
          description: Account name (used for ownership verification)
          required: true
          schema:
            type: string
        - name: pod
          in: query
          description: Pod name
          required: true
          schema:
            type: string
        - name: container
          in: query
          description: Container name (defaults to first container)
          required: false
          schema:
            type: string
        - name: tailLines
          in: query
          description: Number of log lines to return (default 200)
          required: false
          schema:
            type: integer
            default: 200
        - name: Authorization
          in: header
          description: OAuth 2.0 device flow or platform session token
          required: true
          schema:
            type: string
      responses:
        '200':
          description: Log output as plain text
          content:
            application/json:
              schema:
                type: object
                properties: {}
        '400':
          description: Invalid request body or parameters
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
        '401':
          description: Authentication required
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
        '403':
          description: Insufficient permissions for this account
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
        '500':
          description: Server error
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
servers:
  - url: https://astropods.com/api/v1
    description: Astro AI API server
components:
  schemas:
    Error:
      type: object
      properties:
        error:
          type: string
        details:
          type: string
      title: Error
  securitySchemes:
    BearerAuth:
      type: http
      scheme: bearer
      description: OAuth 2.0 device flow or platform session token

```

## Examples



**Request**

```json
{
  "namespace": "astro-agents"
}
```

**Response**

```json
"2024-06-01T12:34:56Z INFO Starting agent process\n2024-06-01T12:34:57Z INFO Agent connected to control plane\n2024-06-01T12:35:00Z WARN Low memory detected, attempting cleanup\n2024-06-01T12:35:05Z INFO Cleanup successful, resuming operations\n2024-06-01T12:35:10Z ERROR Failed to fetch task configuration, retrying\n2024-06-01T12:35:15Z INFO Task configuration fetched successfully\n2024-06-01T12:35:20Z INFO Agent heartbeat sent\n2024-06-01T12:35:25Z INFO Processing task queue\n2024-06-01T12:35:30Z INFO Task completed successfully\n2024-06-01T12:35:35Z INFO Agent idle, waiting for new tasks"
```

**SDK Code**

```python
import requests

url = "https://astropods.com/api/v1/deployments/namespace/logs"

querystring = {"account":"astro-team","pod":"astro-agent-5f7d9c8b6f-xyz12","container":"agent-container","tailLines":"150"}

payload = { "namespace": "astro-agents" }
headers = {
    "Authorization": "Bearer <token>",
    "Content-Type": "application/json"
}

response = requests.get(url, json=payload, headers=headers, params=querystring)

print(response.json())
```

```javascript
const url = 'https://astropods.com/api/v1/deployments/namespace/logs?account=astro-team&pod=astro-agent-5f7d9c8b6f-xyz12&container=agent-container&tailLines=150';
const options = {
  method: 'GET',
  headers: {Authorization: 'Bearer <token>', 'Content-Type': 'application/json'},
  body: '{"namespace":"astro-agents"}'
};

try {
  const response = await fetch(url, options);
  const data = await response.json();
  console.log(data);
} catch (error) {
  console.error(error);
}
```

```go
package main

import (
	"fmt"
	"strings"
	"net/http"
	"io"
)

func main() {

	url := "https://astropods.com/api/v1/deployments/namespace/logs?account=astro-team&pod=astro-agent-5f7d9c8b6f-xyz12&container=agent-container&tailLines=150"

	payload := strings.NewReader("{\n  \"namespace\": \"astro-agents\"\n}")

	req, _ := http.NewRequest("GET", url, payload)

	req.Header.Add("Authorization", "Bearer <token>")
	req.Header.Add("Content-Type", "application/json")

	res, _ := http.DefaultClient.Do(req)

	defer res.Body.Close()
	body, _ := io.ReadAll(res.Body)

	fmt.Println(res)
	fmt.Println(string(body))

}
```

```ruby
require 'uri'
require 'net/http'

url = URI("https://astropods.com/api/v1/deployments/namespace/logs?account=astro-team&pod=astro-agent-5f7d9c8b6f-xyz12&container=agent-container&tailLines=150")

http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true

request = Net::HTTP::Get.new(url)
request["Authorization"] = 'Bearer <token>'
request["Content-Type"] = 'application/json'
request.body = "{\n  \"namespace\": \"astro-agents\"\n}"

response = http.request(request)
puts response.read_body
```

```java
import com.mashape.unirest.http.HttpResponse;
import com.mashape.unirest.http.Unirest;

HttpResponse<String> response = Unirest.get("https://astropods.com/api/v1/deployments/namespace/logs?account=astro-team&pod=astro-agent-5f7d9c8b6f-xyz12&container=agent-container&tailLines=150")
  .header("Authorization", "Bearer <token>")
  .header("Content-Type", "application/json")
  .body("{\n  \"namespace\": \"astro-agents\"\n}")
  .asString();
```

```php
<?php
require_once('vendor/autoload.php');

$client = new \GuzzleHttp\Client();

$response = $client->request('GET', 'https://astropods.com/api/v1/deployments/namespace/logs?account=astro-team&pod=astro-agent-5f7d9c8b6f-xyz12&container=agent-container&tailLines=150', [
  'body' => '{
  "namespace": "astro-agents"
}',
  'headers' => [
    'Authorization' => 'Bearer <token>',
    'Content-Type' => 'application/json',
  ],
]);

echo $response->getBody();
```

```csharp
using RestSharp;

var client = new RestClient("https://astropods.com/api/v1/deployments/namespace/logs?account=astro-team&pod=astro-agent-5f7d9c8b6f-xyz12&container=agent-container&tailLines=150");
var request = new RestRequest(Method.GET);
request.AddHeader("Authorization", "Bearer <token>");
request.AddHeader("Content-Type", "application/json");
request.AddParameter("application/json", "{\n  \"namespace\": \"astro-agents\"\n}", ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
```

```swift
import Foundation

let headers = [
  "Authorization": "Bearer <token>",
  "Content-Type": "application/json"
]
let parameters = ["namespace": "astro-agents"] as [String : Any]

let postData = JSONSerialization.data(withJSONObject: parameters, options: [])

let request = NSMutableURLRequest(url: NSURL(string: "https://astropods.com/api/v1/deployments/namespace/logs?account=astro-team&pod=astro-agent-5f7d9c8b6f-xyz12&container=agent-container&tailLines=150")! as URL,
                                        cachePolicy: .useProtocolCachePolicy,
                                    timeoutInterval: 10.0)
request.httpMethod = "GET"
request.allHTTPHeaderFields = headers
request.httpBody = postData as Data

let session = URLSession.shared
let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in
  if (error != nil) {
    print(error as Any)
  } else {
    let httpResponse = response as? HTTPURLResponse
    print(httpResponse)
  }
})

dataTask.resume()
```