KubeStellar A2A MCP Server
Enables AI-powered management of multi-cluster Kubernetes environments through natural language, supporting kubectl operations, function execution, and agent interactions with multiple AI providers.
README
KubeStellar A2A / MCP
โญโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฎ
โ โโโ โโโโโโ โโโโโโโโโโ โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ โโโ โโโโโโ โโโโโโโ โ
โ โโโ โโโโโโโ โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ โโโ โโโโโโโโโโโโโโโโ โ
โ โโโโโโโ โโโ โโโโโโโโโโโโโโโโโ โโโโโโโโ โโโ โโโโโโ โโโ โโโ โโโโโโโโโโโโโโโโ โ
โ โโโโโโโ โโโ โโโโโโโโโโโโโโโโโ โโโโโโโโ โโโ โโโโโโ โโโ โโโ โโโโโโโโโโโโโโโโ โ
โ โโโ โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ โโโ โโโโโโโโโโโโโโโโโโโโโโโโโโโ โโโโโโ โโโ โ
โ โโโ โโโ โโโโโโโ โโโโโโโ โโโโโโโโโโโโโโโโ โโโ โโโโโโโโโโโโโโโโโโโโโโโโโโโ โโโโโโ โโโ โ
โ Multi-Cluster Kubernetes Management Agent โ
โฐโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฏ
https://github.com/user-attachments/assets/fd5746f9-6620-4aeb-8150-dd9bf9eab694
CLI Setup (uv)
# Enable virtual environment
uv venv
# Install with uv
uv pip install -e ".[dev]"
# Run commands
uv run kubestellar --help
uv run kubestellar list-functions
uv run kubestellar execute <function_name>
uv run kubestellar agent # Start interactive AI agent
kubectl Plugin Installation
You can install and use this project as a kubectl plugin. Primary plugin name is kubestellar (for Krew and release binaries). We also ship a Python-installed alias a2a for convenience. kubectl discovers plugins via executables named kubectl-<name> on your PATH.
Installation options:
# Using uv tool (recommended for per-user install)
uv tool install .
# Using pipx (isolated virtualenv)
pipx install .
# Or directly from GitHub
pipx install 'git+https://github.com/kubestellar/a2a'
# Using pip (installs into current Python environment)
python -m pip install .
Usage:
# kubectl will find the plugin as long as the executable is on PATH
# Python-installed alias (uv/pipx/pip):
kubectl a2a --help
kubectl a2a list-functions
kubectl a2a execute <function_name> -P key=value
kubectl a2a agent
# Krew or release binary name:
kubectl kubestellar --help
kubectl kubestellar list-functions
kubectl kubestellar execute <function_name> -P key=value
kubectl kubestellar agent
Notes:
- The plugin entrypoint is provided by the executable
kubectl-a2a, which is installed via the Python package entry points. This makeskubectl a2abehave the same as running thekubestellarCLI directly. - With
uv tool install, executables are placed under~/.local/binby default. Ensure it is on yourPATH.
Install via Krew
Once a release is published, you can use the generated Krew manifest to install:
# Install from the generated manifest attached to a release (name: kubestellar.yaml)
kubectl krew install --manifest=kubestellar.yaml
# Use the plugin
kubectl kubestellar --help
To make installation available via the central krew-index and install like kubectl krew install kubestellar, submit a PR to https://github.com/kubernetes-sigs/krew-index with the kubestellar.yaml manifest from your release.
Direct install (no package manager)
You can install the plugin by placing a binary named kubectl-kubestellar (or kubectl-kubestellar.exe on Windows) on your PATH. Alternatively, the Python package installs kubectl-a2a which kubectl also discovers.
Option A โ use a release binary (kubectl-kubestellar):
# Download the tarball for your OS/arch from the latest Release
tar -xzf kubectl-kubestellar-<os>-<arch>.tar.gz
chmod +x kubectl-kubestellar
mv kubectl-kubestellar ~/.local/bin/ # or any dir on your PATH
# verify
which kubectl-kubestellar
kubectl plugin list | grep kubestellar || true
kubectl kubestellar --help
Option B โ build locally and copy to PATH (kubectl-kubestellar):
uv sync --dev
uv pip install pyinstaller
uv run pyinstaller --onefile --name kubectl-kubestellar --distpath dist --workpath build packaging/entry_kubectl_a2a.py
install -m 0755 dist/kubectl-kubestellar ~/.local/bin/kubectl-kubestellar
Option C โ reuse the Python entrypoint by symlink (alias a2a):
# If you've installed the package via uv tool/pipx and have `kubestellar` on PATH,
# create a symlink named kubectl-kubestellar pointing to it
ln -sf "$(command -v kubestellar)" ~/.local/bin/kubectl-kubestellar
kubectl kubestellar --help
Windows:
- Use the
.exefrom the Windows release archive and place it in a directory on your%PATH%. - Or create
kubectl-a2a.batforwarding tokubestellar.exeif using a symlink alternative isnโt convenient.
How kubectl plugin discovery works (Kubectl Plugins)
- kubectl discovers plugins by searching your
PATHfor executables namedkubectl-<name>(per the official docs). Examples:kubectl-kubestellar,kubectl-a2a. - When you run
kubectl <name> ..., kubectl executes the firstkubectl-<name>found onPATHand passes through the arguments. - List discovered plugins with
kubectl plugin list. - Krew is a plugin manager that installs such binaries under its own path;
kubectl krew install <name>makes<name>available askubectl <name>. - This project provides
kubectl-kubestellar(for Krew and binary releases) andkubectl-a2a(Python entrypoint). Once on your PATH, usekubectl kubestellar ...orkubectl a2a ....
Reference: https://kubernetes.io/docs/tasks/extend-kubectl/kubectl-plugins/
Get the latest version
For users who installed via uv tool from GitHub:
# Install latest from main
uv tool install --upgrade 'git+https://github.com/kubestellar/a2a@main'
# Or upgrade an existing install (uses original source spec)
uv tool upgrade kubestellar
For pipx installs:
pipx upgrade kubestellar
# or reinstall from GitHub
pipx install --force 'git+https://github.com/kubestellar/a2a@main'
Releasing
This repo includes an automated release workflow that builds platform-specific plugin binaries and publishes a Krew manifest.
Steps:
- Create a version tag and push, e.g.:
git tag v0.1.0 && git push origin v0.1.0 - Or run manually via Actions โ Release โ Run workflow (optional tag input).
- Or publish a GitHub Release with tag
vX.Y.Zto trigger the workflow. - GitHub Actions workflow
.github/workflows/release.ymlruns and produces:- Tarballs for
kubectl-kubestellaron Linux amd64, macOS amd64/arm64, Windows amd64 - SHA256 checksums
kubestellar.yamlKrew manifest with versioned asset URLs and checksums- A GitHub Release containing the above assets
- Tarballs for
Users can then install via Krew using the attached manifest, or you can submit it to the central krew-index.
Troubleshooting release CI
- If the workflow didnโt run: ensure tag matches
v*.*.*, Actions are enabled, and branch protections allow workflows. - For manual runs: use the
workflow_dispatchentry. Optionally provide thetaginput. - For Release events: make sure the release is โpublishedโ (not draft/prerelease) and has a tag like
vX.Y.Z.
Local Plugin Testing
You can test kubectl a2a locally in two ways.
- Using uv tool (recommended):
# From the repo root
uv tool uninstall kubectl-a2a || true
uv tool uninstall kubestellar || true
uv tool install .
# Ensure ~/.local/bin is on PATH, then verify
which kubectl-a2a
kubectl plugin list | grep a2a || true
kubectl a2a --help
kubectl a2a list-functions
# Debug kubectl plugin discovery if needed
kubectl -v=6 a2a --help
- Using a locally built single-file binary (optional):
# Build the binary
uv sync --dev
uv pip install pyinstaller
uv run pyinstaller --onefile --name kubectl-a2a --distpath dist --workpath build packaging/entry_kubectl_a2a.py
# Put it on PATH for this shell and test
export PATH="$PWD/dist:$PATH"
kubectl plugin list | grep a2a || true
kubectl a2a --help
Notes:
- If your shell caches command paths, run
hash -r(bash/zsh) after replacing the binary. - On Windows, ensure
dist/kubectl-a2a.exeis on your PATH. - If you use
piprather thanpipx, ensure the Python scripts directory is on yourPATH(e.g.,~/.local/binon Linux,~/Library/Python/<version>/binon macOS, or the virtual environment'sbin). - For isolated installs,
pipxis the simplest way to getkubectl-a2aonto yourPATH.
AI Provider Configuration
The agent supports multiple AI providers:
Available Providers
- OpenAI (GPT-4, GPT-4o, etc.)
- Google Gemini (gemini-1.5-flash, gemini-1.5-pro, etc.)
Setting Up API Keys
# Set OpenAI API key
uv run kubestellar config set-key openai YOUR_OPENAI_API_KEY
# Set Gemini API key
uv run kubestellar config set-key gemini YOUR_GEMINI_API_KEY
# Set default provider
uv run kubestellar config set-default gemini
# List configured providers
uv run kubestellar config list-keys
# Show current configuration
uv run kubestellar config show
Using Different Providers
# Use default provider
uv run kubestellar agent
# Use specific provider
uv run kubestellar agent --provider gemini
uv run kubestellar agent --provider openai
MCP Server Setup
Add to MCP server (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"kubestellar": {
"command": "uv",
"args": ["run", "kubestellar-mcp"],
"cwd": "/path/to/a2a"
}
}
}
Documentation
๐ Complete Documentation: https://kubestellar.io/docs/a2a
License
This project is licensed under the Apache 2.0 License - see the LICENSE file for details.
Acknowledgments
- Built with MCP SDK
- Inspired by the KubeStellar project for multi-cluster Kubernetes management
- Thanks to all contributors and the open-source community
Made with โค๏ธ by the KubeStellar community
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.