Provides tools for monitoring and analyzing Kubernetes cluster alerts through Karma Alert dashboard, including listing alerts by cluster, filtering by severity and state, and retrieving detailed alert information.
🚨 Karma MCP Server
Bring AI-powered intelligence to your Kubernetes alerts. Karma MCP Server enables Claude to directly interact with your Karma Alert Dashboard, providing natural language queries, analysis, and management of Prometheus/Alertmanager alerts.
🌟 What is This?
Karma MCP Server is a bridge that connects Claude Desktop (or any MCP-compatible client) to your Karma Alert Dashboard. This allows you to:
🗣️ Ask questions in natural language about your alerts: "How many critical alerts are there in production?"
🔍 Search and filter across multiple Kubernetes clusters simultaneously
📊 Get instant insights about alert patterns and trends
🚀 Accelerate incident response with AI-powered alert analysis
🔄 Automate routine checks without leaving your conversation
Example Interactions with Claude
🎯 Key Features
Core Alert Management
✅ Real-time alert listing with severity, state, and cluster information
✅ Multi-cluster support - search across all your Kubernetes clusters at once
✅ Smart filtering by cluster, namespace, severity, and alert state
✅ Detailed alert inspection with annotations, labels, and runbook links
✅ Statistical summaries showing alert distribution and trends
Advanced Capabilities
🔍 Alert name search - Search specific alerts by pattern matching
🔍 State filtering - Filter by active, suppressed, or all states
🔍 Cross-cluster analysis - Compare alert patterns between environments
Integration Features
🔄 MCP Protocol support for AI assistants
🐳 Docker support with multi-architecture images
☸️ Kubernetes-ready deployment
📦 Installation
Quick Start with Claude Desktop
Install via UV (recommended)
Configure Claude Desktop, Claude Code, or Cursor
Local Installation (Stdio Mode)
Add to your MCP client configuration:
Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json
):
Claude Code (add to project's claude_desktop_config.json
or global config):
Cursor (via MCP extension or custom configuration):
Remote HTTP Server (Alternative)
If you have deployed the HTTP server version, use SSE transport:
Connect to your Karma instance
Restart Claude Desktop and start asking about your alerts!
Docker Installation
Kubernetes Deployment
🛠️ Available MCP Tools
The following tools are available for Claude to use:
Tool | Description | Example Query |
| Verify Karma connectivity | "Is Karma accessible?" |
| List all active alerts | "Show me all alerts" |
| Statistical summary by severity/state | "Give me an alert summary" |
| Detailed info about specific alert | "Details about KubePodCrashLooping" |
| List all K8s clusters with counts | "Which clusters have alerts?" |
| Filter by cluster | "Show teddy-prod alerts" |
| Show only active alerts | "What's currently firing?" |
| Show silenced/inhibited | "What alerts are suppressed?" |
| Filter by state (active/suppressed/all) | "Show all suppressed alerts" |
| Search alerts by name pattern | "Find all OOM alerts" |
| Create alert silence | "Silence KubePodCrashLooping for 2h" |
🧠 AI-Enhanced Analysis
The Karma MCP Server includes specialized prompts that help Claude provide more valuable alert analysis:
📚 Available Prompt Resources
Resource | Purpose | Description |
| Alert Analysis | Comprehensive guidelines for troubleshooting common K8s alerts |
| Incident Response | Escalation procedures and communication templates |
| K8s Context | Deep Kubernetes knowledge for alert interpretation |
| Business Impact | Prioritization framework based on service criticality |
🎯 Enhanced Capabilities
With these prompts, Claude can:
🔍 Correlate related alerts across clusters and namespaces
🚨 Prioritize by business impact (prod > staging > dev)
🔧 Suggest specific actions for common alert types
📊 Provide context about Kubernetes resource relationships
🚀 Guide incident response with escalation procedures
🔌 API Integration
The server runs as an MCP server using stdio protocol for communication with Claude Desktop. For programmatic access, you can call the MCP tools directly from your Python code:
🧪 Testing
🔧 Development
Setting up the development environment
Task Runner: Just vs Make
This project uses Just as the modern task runner (alternative to Make). Key benefits:
✅ No tab/space issues (common Make problem)
✅ Better variable handling and environment integration
✅ Cleaner syntax and cross-platform compatibility
✅ Built-in command listing with
just
✅ Modern features like default values and string interpolation
Manual Development Commands
If you prefer direct commands or don't have Just installed:
Project Structure
📊 Real-World Use Cases
Daily Operations
Morning standup: "Show me all critical alerts from the last 24 hours"
Shift handover: "Summarize current active alerts by cluster"
Quick checks: "Are there any database-related alerts?"
Incident Response
Investigation: "Find all alerts related to the payment service"
Pattern detection: "Show me crash loops in the API namespace"
Impact analysis: "Which clusters are affected by high CPU throttling?"
Capacity Planning
Resource issues: "List all OOM killed containers this week"
Scaling decisions: "Show pods with high memory pressure"
Performance: "Find all high latency alerts"
🤝 Contributing
We welcome contributions! Please see our Contributing Guide for details.
Areas we'd love help with:
📈 Historical trending and analytics
🔐 Authentication support for secured Karma instances
🌍 Additional language support for alert descriptions
📱 Slack/Teams notification integrations
🤖 AI-powered alert correlation and root cause analysis
📝 License
This project is licensed under the MIT License - see the LICENSE file for details.
🙏 Acknowledgments
Karma Alert Dashboard - The excellent alert dashboard that makes this possible
Model Context Protocol - Anthropic's protocol for AI tool integration
FastMCP - Simplified MCP server development
The Kubernetes and Prometheus communities for their amazing monitoring ecosystem
📚 Documentation
Configuration: Set
KARMA_URL
environment variable to your Karma instanceTroubleshooting: Check the GitHub Issues for common problems
Examples: See the "Real-World Use Cases" section above for query examples
🚀 Roadmap
Completed ✅
Core alert querying and filtering
Multi-cluster support
State-based filtering (active/suppressed)
Docker containerization
CI/CD with GitHub Actions
Alert search by pattern
Alert silencing capability
In Progress 🔨
Alert acknowledgment
Silence management (list/delete)
Future Plans 💭
Historical data and trending
Alert correlation analysis
Grafana integration
Authentication for secured Karma instances
Need help? Open an issue or reach out on GitHub Discussions
Like this project? Give it a ⭐ on GitHub!
This server cannot be installed
hybrid server
The server is able to function both locally and remotely, depending on the configuration or use case.
Enables Claude to interact with Karma Alert dashboard to monitor and analyze Kubernetes alerts. Provides tools to check alert status, filter by cluster/severity, get detailed alert information, and analyze alert statistics and trends.