Skip to main content

MCP server for Talos Linux API integration - manage clusters with AI

Project description

Talos MCP Server

An MCP (Model Context Protocol) server that provides seamless integration with Talos Linux clusters. This server enables Claude to interact with your Talos infrastructure through the native gRPC API.

Features

  • ๐Ÿ”Œ MCP Resources: Direct access to node health, version, and config via URI
  • ๐Ÿ“ MCP Prompts: Intelligent templates for diagnosing clusters and reviewing audits
  • ๐Ÿ”ง Cluster Management: Bootstrap, upgrade, reset, and manage node lifecycle
  • ๐Ÿ’พ Disk & Hardware: Inspect disks, mounts, PCI, USB, and system devices
  • ๐Ÿ“Š Monitoring: Access logs, dmesg, services, and real-time dashboard data
  • ๐Ÿ” File System: Browse and read files on Talos nodes
  • ๐Ÿ” etcd Integration: Manage members, snapshots, alarms, and defragmentation
  • โ˜ธ๏ธ Kubernetes Config: Retrieve kubeconfig for cluster access
  • โš™๏ธ Configuration: Patches, validation, and machine config management
  • ๐Ÿ“ก Resource Inspection: Query any Talos resource (similar to kubectl get)

What is Talos Linux?

Talos Linux is a modern, secure, and immutable Linux distribution designed specifically for Kubernetes. Key features:

  • API-Managed: Completely managed via a declarative gRPC API (no SSH)
  • Immutable: Read-only root filesystem for enhanced security
  • Minimal: Only includes components necessary to run Kubernetes
  • Secure by Default: Kernel hardened following KSPP recommendations

Prerequisites

  1. Python 3.10+
  2. uv - Fast Python package installer
  3. talosctl - Talos CLI tool
  4. Talos Configuration - A valid talosconfig file (usually at ~/.talos/config)

Installation

Option 1: Install from PyPI (Recommended)

pip install talos-mcp-server

Or with uv:

uv pip install talos-mcp-server

Option 2: Install from Source

git clone https://github.com/CBEPX/talos-mcp-server.git
cd talos-mcp-server
uv venv && source .venv/bin/activate
uv pip install -e .

Install talosctl

# macOS
brew install siderolabs/tap/talosctl

# Linux
curl -sL https://talos.dev/install | sh

4. Docker Support

You can also run the server using Docker.

# Build the image
docker build -t talos-mcp-server .

# Run the container (make sure to mount your talos config)
docker run --rm -i \
  -v $HOME/.talos:/root/.talos:ro \
  -e TALOSCONFIG=/root/.talos/config \
  talos-mcp-server

Or using Docker Compose for development:

docker-compose up --build

Configuration

Talos Configuration

Ensure you have a valid Talos configuration file. This is typically created when you set up your Talos cluster:

# Generate config (if setting up new cluster)
talosctl gen config my-cluster https://<control-plane-ip>:6443

# Check your current config
talosctl config info

# View available contexts
talosctl config contexts

The MCP server will automatically use your default Talos configuration from ~/.talos/config.

Client Integration

Claude Desktop

To use this MCP server with Claude Desktop, add it to your configuration:

macOS: ~/Library/Application Support/Claude/claude_desktop_config.json Windows: %APPDATA%\Claude\claude_desktop_config.json

{
  "mcpServers": {
    "talos": {
      "command": "talos-mcp-server",
      "env": {
        "TALOSCONFIG": "/path/to/your/.talos/config",
        "TALOS_MCP_LOG_LEVEL": "INFO",
        "TALOS_MCP_AUDIT_LOG_PATH": "talos_mcp_audit.log"
      }
    }
  }
}

Cursor

  1. Open Cursor Settings
  2. Go to Features > MCP Servers
  3. Click + Add New MCP Server
  4. Fill in the details:
    • Name: talos
    • Type: stdio
    • Command: talos-mcp-server
    • Environment Variables: Add TALOSCONFIG pointing to your config file

Google Antigravity / Generic JSON

For other clients supporting the Model Context Protocol (including Perplexity or generic integrations), use the standard server definition. You can configure the server using CLI arguments (Typer) or Environment Variables.

Example using CLI arguments:

{
  "mcpServers": {
    "talos": {
      "command": "talos-mcp-server",
      "args": [
        "--log-level", "DEBUG",
        "--readonly"
      ],
      "env": {
        "TALOSCONFIG": "${HOME}/.talos/config"
      }
    }
  }
}

Example using Environment Variables:

{
  "mcpServers": {
    "talos": {
      "command": "talos-mcp-server",
      "env": {
        "TALOSCONFIG": "${HOME}/.talos/config",
        "TALOS_MCP_READONLY": "true",
        "TALOS_MCP_LOG_LEVEL": "INFO"
      }
    }
  }
}

Configuration Options

The server uses Typer for CLI arguments and Pydantic Settings for environment variables. You can mix and match, but CLI arguments take precedence.

Environment Variable CLI Argument Description Default
TALOSCONFIG N/A Path to talosconfig file ~/.talos/config
TALOS_MCP_LOG_LEVEL --log-level Logging verbosity (DEBUG, INFO, etc) INFO
TALOS_MCP_AUDIT_LOG_PATH --audit-log Path to JSON audit log file talos_mcp_audit.log
TALOS_MCP_READONLY --readonly / --no-readonly Enable/Disable read-only mode false

Available Tools

Cluster Lifecycle

  • talos_bootstrap: Bootstrap the cluster on a node
  • talos_upgrade: Upgrade Talos on a node
  • talos_reset: Reset a node to maintenance mode
  • talos_reboot: Reboot a node
  • talos_shutdown: Shutdown a node
  • talos_cluster_show: High-level cluster overview

Configuration & Management

  • talos_config_info: Get current Talos configuration and context
  • talos_apply_config / talos_apply: Apply configuration
  • talos_patch: Apply generic patches to resources
  • talos_machineconfig_patch: Patch machine configuration
  • talos_validate_config: Validate configuration files
  • talos_get_kubeconfig: Retrieve kubeconfig

System & Hardware

  • talos_get_version: Get Talos Linux version
  • talos_health: Check cluster health status
  • talos_get_disks: List disks
  • talos_devices: List PCI, USB, and System devices
  • talos_mounts: List mount points
  • talos_du: Disk usage analysis
  • talos_dashboard: Real-time resource usage snapshot

Network & Services

  • talos_get_services: Service status
  • talos_interfaces: List network interfaces
  • talos_routes: List network routes
  • talos_netstat: Network connections
  • talos_pcap: Capture packet data
  • talos_logs: Service/Container logs
  • talos_dmesg: Kernel logs

Resources & Etcd

  • talos_get_resources: Query any Talos resource
  • talos_list: List files
  • talos_read: Read files
  • talos_etcd_members: List etcd members
  • talos_etcd_snapshot: Take etcd snapshot
  • talos_etcd_alarm: Manage etcd alarms
  • talos_etcd_defrag: Defragment etcd storage

New Features (Talos 1.12+)

  • talos_cgroups: Manage cgroups
  • talos_volumes: Manage user volumes
  • talos_support: Generate support bundles

Usage Examples

With Claude Desktop

Once configured, you can ask Claude natural language questions:

"Show me the version of Talos running on my cluster"

"What services are running on node 192.168.1.10?"

"Get the logs from kubelet on my control plane nodes"

"List all disks on 192.168.1.10"

"Check the health of my Talos cluster"

"Show me the etcd members"

Programmatic Usage

from talos_mcp.server import TalosClient

# Initialize client
client = TalosClient()

# Get context info
info = client.get_context_info()
print(info)

# Execute talosctl commands
result = await client.execute_talosctl(["version"])
print(result["stdout"])

Development

Running Tests

# Install dev dependencies
uv pip install -e ".[dev]"

# Run unit tests
pytest

# Run integration tests (Requires Docker)
# This will provision a local Talos cluster in Docker
make test-integration

Code Quality

We use a comprehensive set of tools to ensure code quality:

# Standard development workflow using Makefile
make install      # Install dependencies
make lint         # Run all linters (ruff, mypy, bandit)
make test         # Run tests
make verify       # Verify tool registration

Logging and Auditing

The server uses loguru for structured logging.

  • Console: INFO level logs for general feedback.
  • Audit Log: talos_mcp_audit.log (rotating) containing detailed JSON logs for debugging and auditing commands.

Architecture

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  Claude Desktop โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
         โ”‚ MCP Protocol
         โ†“
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  MCP Server (Python)                โ”‚
โ”‚  โ”œโ”€ cli.py (CLI & Lifecycle)        โ”‚
โ”‚  โ”œโ”€ handlers.py (Protocol Handlers) โ”‚
โ”‚  โ”œโ”€ registry.py (Auto-Discovery)    โ”‚
โ”‚  โ””โ”€ server.py (Initialization)      โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
         โ”‚ subprocess
         โ†“
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚   talosctl CLI  โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
         โ”‚ gRPC + mTLS
         โ†“
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  Talos Cluster  โ”‚
โ”‚   (apid API)    โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Key Components

  • cli.py: Command-line interface, logging, and server lifecycle
  • server.py: MCP server initialization and handler registration
  • handlers.py: MCP protocol handlers (Resources, Prompts, Tools)
  • registry.py: Auto-discovery and registration of tools
  • core/: Client, settings, and exception handling
  • tools/: Modular tool implementations (auto-discovered)

Security Considerations

  1. mTLS Authentication: Talos API uses mutual TLS for authentication
  2. Certificate Management: Keep your talosconfig and certificates secure
  3. Network Access: Ensure your endpoints are properly firewalled
  4. Permissions: The MCP server has the same permissions as your talosconfig

Troubleshooting

talosctl not found

# Check if talosctl is in PATH
which talosctl

# Install talosctl if missing
curl -sL https://talos.dev/install | sh

Configuration not found

# Check config location
echo $TALOSCONFIG

# Verify config exists
ls -la ~/.talos/config

# Test connectivity
talosctl version

Connection refused

# Verify endpoints in config
talosctl config info

# Check network connectivity
ping <control-plane-ip>

# Verify certificates are valid
talosctl version --nodes <node-ip>

MCP Server Issues

# Test the server directly
talos-mcp-server --help

# Check Claude Desktop logs
# macOS: ~/Library/Logs/Claude/
# Windows: %APPDATA%\Claude\logs\

Resources

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

MIT License - see LICENSE file for details

Acknowledgments

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

talos_mcp_server-0.3.10.tar.gz (180.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

talos_mcp_server-0.3.10-py3-none-any.whl (43.4 kB view details)

Uploaded Python 3

File details

Details for the file talos_mcp_server-0.3.10.tar.gz.

File metadata

  • Download URL: talos_mcp_server-0.3.10.tar.gz
  • Upload date:
  • Size: 180.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for talos_mcp_server-0.3.10.tar.gz
Algorithm Hash digest
SHA256 4522324ab173494261f90c906440eeab39c3a5b0ce4deb8799e7e6992729321b
MD5 26f5cb03fa2d9e28be948faefe43f923
BLAKE2b-256 564186dc55ea8d024857eb77eb5fc601974050560c747522dbaa629c85c8e626

See more details on using hashes here.

Provenance

The following attestation bundles were made for talos_mcp_server-0.3.10.tar.gz:

Publisher: ci.yml on CBEPX/talos-mcp-server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file talos_mcp_server-0.3.10-py3-none-any.whl.

File metadata

File hashes

Hashes for talos_mcp_server-0.3.10-py3-none-any.whl
Algorithm Hash digest
SHA256 b9bfd45bb42a807c95cd4f0de38c310f31393274afbb5d2d80304028710ff973
MD5 0647b6b8bb2fa9e5c6e2a8e63d4660cc
BLAKE2b-256 413575e64b85a92124edc7635ab04502dc865e0c7d06cb922dad298fcde401f9

See more details on using hashes here.

Provenance

The following attestation bundles were made for talos_mcp_server-0.3.10-py3-none-any.whl:

Publisher: ci.yml on CBEPX/talos-mcp-server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page