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
- Python 3.10+
- uv - Fast Python package installer
- talosctl - Talos CLI tool
- 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
- Open Cursor Settings
- Go to Features > MCP Servers
- Click + Add New MCP Server
- Fill in the details:
- Name:
talos - Type:
stdio - Command:
talos-mcp-server - Environment Variables: Add
TALOSCONFIGpointing to your config file
- Name:
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
- mTLS Authentication: Talos API uses mutual TLS for authentication
- Certificate Management: Keep your talosconfig and certificates secure
- Network Access: Ensure your endpoints are properly firewalled
- 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
- Built for the Model Context Protocol
- Integrates with Talos Linux by Sidero Labs
- Uses uv for fast Python package management
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4522324ab173494261f90c906440eeab39c3a5b0ce4deb8799e7e6992729321b
|
|
| MD5 |
26f5cb03fa2d9e28be948faefe43f923
|
|
| BLAKE2b-256 |
564186dc55ea8d024857eb77eb5fc601974050560c747522dbaa629c85c8e626
|
Provenance
The following attestation bundles were made for talos_mcp_server-0.3.10.tar.gz:
Publisher:
ci.yml on CBEPX/talos-mcp-server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
talos_mcp_server-0.3.10.tar.gz -
Subject digest:
4522324ab173494261f90c906440eeab39c3a5b0ce4deb8799e7e6992729321b - Sigstore transparency entry: 943934555
- Sigstore integration time:
-
Permalink:
CBEPX/talos-mcp-server@fda821145e528abe1bc4995bf883b1a9c719dada -
Branch / Tag:
refs/tags/v0.3.10 - Owner: https://github.com/CBEPX
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
ci.yml@fda821145e528abe1bc4995bf883b1a9c719dada -
Trigger Event:
push
-
Statement type:
File details
Details for the file talos_mcp_server-0.3.10-py3-none-any.whl.
File metadata
- Download URL: talos_mcp_server-0.3.10-py3-none-any.whl
- Upload date:
- Size: 43.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b9bfd45bb42a807c95cd4f0de38c310f31393274afbb5d2d80304028710ff973
|
|
| MD5 |
0647b6b8bb2fa9e5c6e2a8e63d4660cc
|
|
| BLAKE2b-256 |
413575e64b85a92124edc7635ab04502dc865e0c7d06cb922dad298fcde401f9
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
talos_mcp_server-0.3.10-py3-none-any.whl -
Subject digest:
b9bfd45bb42a807c95cd4f0de38c310f31393274afbb5d2d80304028710ff973 - Sigstore transparency entry: 943934559
- Sigstore integration time:
-
Permalink:
CBEPX/talos-mcp-server@fda821145e528abe1bc4995bf883b1a9c719dada -
Branch / Tag:
refs/tags/v0.3.10 - Owner: https://github.com/CBEPX
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
ci.yml@fda821145e528abe1bc4995bf883b1a9c719dada -
Trigger Event:
push
-
Statement type: