kafka-mcp
Exposes Kafka administration operations as MCP tools, enabling AI agents to inspect Kafka clusters using natural language.
README
š¦ kafka-mcp
An MCP server that gives your AI agents eyes into Apache Kafka.
kafka-mcp exposes Kafka administration operations as Model Context Protocol tools, so assistants like
Claude Desktop, Claude Code, or any MCP-compatible client can inspect and operate your cluster in plain language ā
"list all my topics with their replication factor" ā instead of you reaching for the CLI.
It ships with a batteries-included docker-compose.yml that spins up a complete local Kafka lab
(KRaft broker + Schema Registry + Web UI) so you can try it end-to-end in minutes.
<p align="left"> <img alt="Python" src="https://img.shields.io/badge/python-3.12+-3776AB?logo=python&logoColor=white"> <img alt="MCP" src="https://img.shields.io/badge/protocol-MCP-6E56CF"> <img alt="Apache Kafka" src="https://img.shields.io/badge/Apache-Kafka-231F20?logo=apachekafka&logoColor=white"> <img alt="uv" src="https://img.shields.io/badge/built%20with-uv-DE5FE9"> </p>
⨠Features
- š Drop-in MCP server ā runs over
stdio, so any MCP client can launch it as a subprocess. - š Topic management ā list & describe topics, create / delete, add partitions, and read or alter configs.
- š„ Consumer group insight ā list & describe groups, inspect members & assignments, and compute per-partition lag.
- šØ Produce & peek ā send a message to a topic, or read recent records back without committing offsets.
- 𩺠Cluster & offset views ā describe brokers / controller and fetch earliest / latest watermarks per partition.
- ā” Async-friendly ā blocking Kafka admin calls are offloaded to worker threads so the event loop stays snappy.
- š³ Self-contained local lab ā one
docker compose upgives you Kafka (KRaft, no ZooKeeper), Schema Registry, and a Web UI. - š ļø Tiny & hackable ā a single module (
src/zaksway_kafka_mcp/__init__.py) you can read in one sitting and extend with new tools.
š§ How it works
āāāāāāāāāāāāāāāāāāāā MCP over stdio āāāāāāāāāāāāāāāāāāāā Kafka Admin API āāāāāāāāāāāāāāāāāāāā
ā AI Agent ā āāāāāāāāāāāāāāāāā¶ ā kafka-mcp ā āāāāāāāāāāāāāāāāāā¶ ā Kafka broker ā
ā (Claude, etc.) ā tool calls ā (FastMCP server)ā confluent-kafka ā (localhost:9092)ā
āāāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāāā
The agent never talks to Kafka directly ā it calls a tool, kafka-mcp translates that into a
confluent-kafka admin or client request, and returns structured JSON the model can reason about.
š¦ Prerequisites
- Python 3.12+
- uv for dependency management (recommended)
- Docker + Docker Compose (only if you want the local Kafka lab)
š Quick start
1. Clone & install
git clone <your-repo-url> kafka-mcp
cd kafka-mcp
uv sync
2. Start a local Kafka (optional, but handy)
docker compose up -d
This brings up three services:
| Service | URL / Port | What it's for |
|---|---|---|
| Kafka broker | localhost:9092 |
The broker your MCP server connects to |
| Schema Registry | http://localhost:8081 |
Avro/Protobuf/JSON schema management |
| Kafka UI | http://localhost:8080 |
Browse topics, messages, and consumer groups |
š” Auto-create topics is enabled, so you can produce to a new topic and watch it appear via the MCP
list_topicstool.
3. Run the MCP server
uv run kafka-zaksway
You should see:
Kafka MCP for you agents!
The server is now listening on stdio, ready for an MCP client to connect.
š¤ Connecting an MCP client
Most clients (Claude Desktop, Claude Code, ā¦) launch MCP servers from a JSON config. Once it's installed from PyPI, point them at the published package ā no clone required:
{
"mcpServers": {
"kafka-zaksway": {
"command": "uvx",
"args": ["zaksway-kafka-mcp"],
"env": {
"BOOTSTRAP_SERVER": "localhost:9092"
}
}
}
}
- Claude Desktop ā add the block to
claude_desktop_config.json. - Claude Code ā
claude mcp add kafka-zaksway -- uvx zaksway-kafka-mcp
š” Hacking on a local clone instead? Swap to
"command": "uv"with"args": ["--directory", "/absolute/path/to/zaksway-kafka-mcp", "run", "kafka-zaksway"].
Restart the client, and kafka-zaksway will appear among your available tools.
š§° Available tools
kafka-mcp exposes 14 tools spanning topic management, consumer groups, the cluster, and the data plane.
Tools marked ā ļø are destructive (they delete data) ā agents should confirm before calling them.
| Category | Tool | Parameters | Description |
|---|---|---|---|
| Topics | list_topics |
withInternal: bool |
List topics with partition count & replication factor. |
| Topics | describe_topic |
topic: str |
Per-partition leader / replicas / ISR + non-default config overrides. |
| Topics | create_topic |
topic: str, partitions: int = 1, replication_factor: int = 1, config: dict = {} |
Create a new topic. |
| Topics | delete_topic ā ļø |
topic: str |
Permanently delete a topic and all of its data. |
| Topics | add_partitions |
topic: str, new_total_count: int |
Increase a topic's partition count (cannot shrink). |
| Topics | alter_topic_config |
topic: str, config: dict |
Set / update topic configuration entries. |
| Topics | get_topic_offsets |
topic: str |
Earliest & latest offsets (watermarks) per partition. |
| Cluster | describe_cluster |
ā | Cluster id, controller broker, and broker list. |
| Groups | list_consumer_groups |
ā | All consumer groups with their state. |
| Groups | describe_consumer_group |
group_id: str |
State, coordinator, members & their partition assignments. |
| Groups | consumer_group_lag |
group_id: str |
Committed offset, end offset, and lag per partition. |
| Groups | delete_consumer_group ā ļø |
group_id: str |
Permanently delete a consumer group. |
| Data | produce_message |
topic: str, value: str, key: str = null, partition: int = null |
Produce a single message and await delivery. |
| Data | consume_messages |
topic: str, max_messages: int = 10, timeout_seconds: float = 5.0, from_beginning: bool = true |
Peek recent messages without committing offsets. |
š” The registered MCP tool names are full descriptive sentences (e.g.
Show committed offsets and lag for a Kafka consumer group); the short identifiers above mirror the Python functions insrc/zaksway_kafka_mcp/__init__.pyand are used here for brevity.
Example ā list_topics response:
[
{ "name": "orders", "partitions": 6, "replication-factor": 1 },
{ "name": "payments", "partitions": 3, "replication-factor": 1 }
]
āļø Configuration
The server is configured entirely through environment variables.
| Variable | Default | Description |
|---|---|---|
BOOTSTRAP_SERVER |
localhost:9092 |
Kafka bootstrap server(s) to connect to. |
š¦ Releasing to PyPI
The package is published to PyPI as zaksway-kafka-mcp by a GitHub Actions workflow (.github/workflows/publish.yml) that triggers on v* version tags and authenticates via Trusted Publishing (OIDC) ā no API tokens stored anywhere.
One-time setup ā register a Trusted Publisher on PyPI:
| Field | Value |
|---|---|
| Owner | zakariahere |
| Repository | zaksway-kafka-mcp |
| Workflow filename | publish.yml |
| Environment | pypi |
To cut a release:
# 1. Bump `version` in pyproject.toml (e.g. 0.1.0 -> 0.2.0), then:
git commit -am "release: v0.2.0"
git tag v0.2.0
git push origin master --tags
The workflow verifies the tag matches pyproject.toml, builds the wheel + sdist, smoke-tests both, and publishes. Once published, anyone can run it with zero install:
uvx zaksway-kafka-mcp # run the server directly
# or
pip install zaksway-kafka-mcp # then run: kafka-zaksway
šļø Project structure
kafka-mcp/
āāā src/zaksway_kafka_mcp/
ā āāā __init__.py # The MCP server + all 14 tool definitions
ā āāā __main__.py # `python -m zaksway_kafka_mcp` entry point
āāā tests/
ā āāā smoke_test.py # Import/packaging check run in CI before publish
āāā .github/workflows/
ā āāā publish.yml # Build + publish to PyPI on `v*` tags (Trusted Publishing)
āāā docker-compose.yml # Local Kafka lab (broker + schema registry + UI)
āāā pyproject.toml # Project metadata, dependencies & build backend
āāā uv.lock # Pinned dependency lockfile
āāā README.md # You are here
š£ļø Roadmap
Recently shipped ā
- [x]
create_topic/delete_topic - [x]
add_partitions&alter_topic_config - [x] Describe consumer groups & their lag
- [x] Peek at the latest messages on a topic
Ideas for what's next:
- [ ] Reset / set consumer group offsets
- [ ] ACL management (list / create / delete)
- [ ] Broker config inspection
- [ ] Schema Registry integration (list subjects & schemas)
š§āš» Author
Zakaria BOUAZZA : https://zakaria.lu
š License
No license has been specified yet. Add one (e.g. MIT) before sharing publicly.
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.