Kafka MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Kafka MCP ServerList all Kafka topics"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Kafka MCP Server
This project provides a Model Context Protocol (MCP) server that enables interaction with a Kafka cluster via standard tool-based interfaces. It exposes Kafka operations like producing messages, consuming, listing topics, and more — all accessible through Claude Desktop or any MCP-compatible client.
🛠 Features
List Kafka topics
Create and delete topics
Produce messages
🚀 Quick Start
1. Clone the repository
git clone https://github.com/joel-hanson/kafka-mcp-server.git
cd kafka-mcp-server2. Setup Python environment (using conda)
conda create -n kafka-mcp python=3.10 -y
conda activate kafka-mcp
pip install -r requirements.txt3. Start the MCP server (for local dev)
mcp devThis starts the server and opens the MCP Inspector so you can test tool prompts and responses.
Usage
Running the Server
python server.pyAvailable Tools
kafka_initialize_connection - Connect to Kafka using a properties file
kafka_list_topics - List all topics in the cluster
kafka_create_topic - Create a new topic
kafka_delete_topic - Delete an existing topic
kafka_get_topic_info - Get detailed information about a topic
Example Usage Flow
First, connect to Kafka:
Use kafka_initialize_connection with your properties file <path> OR Initialize connection with kafka using the properties file <path>List existing topics:
Use kafka_list_topics to see all topics OR List all the topicsCreate a new topic:
Use kafka_create_topic with name "my-topic", partitions 3, replication_factor 1 OR Create me a topic with name "my-topic"Get topic details:
Use kafka_get_topic_info for "my-topic"
Features
Configuration Management: Loads Kafka connection details from standard properties files
Topic Management: List, create, delete, and inspect topics
Error Handling: Comprehensive error handling with informative messages
Connection Management: Efficient connection pooling and cleanup
Extensible: Easy to add more Kafka operations
Supported Kafka Operations
Current
Topic listing
Topic creation with custom partitions and replication factor
Topic deletion
Topic inspection (partitions, replicas, ISR)
Planned Features
Message production
Message consumption
Consumer group management
Offset management
Cluster information
Performance metrics
Troubleshooting
Common Issues
Connection Failed: Verify your
bootstrap.serversin the properties fileAuthentication Error: Check your SASL/SSL configuration
Topic Already Exists: Use
kafka_get_topic_infoto check existing topicsPermission Denied: Ensure your Kafka user has the necessary permissions
Logging
The server logs to stdout. You can adjust the logging level by modifying the logging.basicConfig(level=logging.INFO) line in the code.
Security Notes
Store sensitive credentials securely
Use SSL/TLS for production environments
Implement proper authentication and authorization
Regularly rotate credentials
🧠 Using with Claude Desktop
To integrate your Kafka MCP server with Claude Desktop:
Install it into Claude:
mcp install <file_spec> -f <optional env file>Note: If you are seeing dependency-related issues, please configure the claud_desktop_config.json with the absolute path to the python and provide the file to run.
MCP Client Configuration
Add this to your MCP client configuration (e.g., Claude Desktop):
{
"mcpServers": {
"kafka": {
"command": "python",
"args": ["/path/to/server.py"]
}
}
}{
"mcpServers": {
"Kafka MCP Server": {
"command": "/opt/miniconda3/envs/kafka-mcp/bin/python",
"args": [
"/path/to/server.py"
]
}
}
}Claude will now detect and interact with the tools you've defined via @mcp.prompt() in your Python server.
Configuration
Create a Kafka properties file (e.g., kafka.properties) with your Kafka connection details:
# Basic Kafka connection
bootstrap.servers=localhost:9092
client.id=kafka-mcp-client
# Security configuration (if needed)
# security.protocol=SASL_SSL
# sasl.mechanism=PLAIN
# sasl.username=your-username
# sasl.password=your-password
# SSL configuration (if needed)
# ssl.ca.location=/path/to/ca-cert
# ssl.certificate.location=/path/to/client-cert
# ssl.key.location=/path/to/client-key📂 Project Structure
kafka_mcp_server/
├── server.py # Main FastMCP server defining tools
├── kafka_utils.py
├── requirements.txt
├── README.md
└── ...🧩 Tool Debugging Tips
Use
mcp devto inspect prompt behavior interactivelyAdd
print()orlogging.debug()in your tool functionsUse structured
@promptfunction signatures to ensure correct parsing
📦 Requirements
Add this to your requirements.txt:
kafka-python
mcp[cli]
pydantic
uvTesting
Please run docker compose up to bring up kafka cluster with a single broker you can interact with using the bootstrap.server localhost:9092.
🔗 Resources
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Joel-hanson/kafka-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server