什么是 Komodo MCP Server?
Manage Komodo through AI assistants
README
MCP Komodo
MCP server for the Komodo DevOps platform. Manage servers, stacks, deployments, builds, and more through natural language in Cursor, Claude Code, and Claude Desktop.
Features
- 53 tools across 13 categories covering the complete Komodo DevOps API
- Three access tiers (
read-only,read-execute,full) for granular control - Category filtering via
KOMODO_CATEGORIESto expose only the tools you need - Zero HTTP dependencies -- uses the official
komodo_clientSDK - Docker images for
linux/amd64andlinux/arm64on GHCR - Remote MCP via HTTP transport (
MCP_TRANSPORT=http) using the Streamable HTTP protocol - TypeScript/ESM with full type safety
API Compatibility
Built for Komodo 1.19.5.
Quick Start
Run the server directly with npx:
KOMODO_URL="https://komodo.example.com" \
KOMODO_API_KEY="your-api-key" \
KOMODO_API_SECRET="your-api-secret" \
npx -y @samik081/mcp-komodo
The server validates your Komodo connection on startup and fails immediately with a clear error if credentials are missing or invalid.
Docker
Run with Docker (stdio transport, same as npx):
docker run --rm -i \
-e KOMODO_URL=https://komodo.example.com \
-e KOMODO_API_KEY=your-api-key \
-e KOMODO_API_SECRET=your-api-secret \
ghcr.io/samik081/mcp-komodo
To run as a remote MCP server with HTTP transport:
docker run -d -p 3000:3000 \
-e MCP_TRANSPORT=http \
-e KOMODO_URL=https://komodo.example.com \
-e KOMODO_API_KEY=your-api-key \
-e KOMODO_API_SECRET=your-api-secret \
ghcr.io/samik081/mcp-komodo
The MCP endpoint is available at http://localhost:3000 and a health check at http://localhost:3000/health.
Configuration
Claude Code CLI (recommended):
# Using npx
claude mcp add --transport stdio komodo \
--env KOMODO_URL=https://komodo.example.com \
--env KOMODO_API_KEY=your-api-key \
--env KOMODO_API_SECRET=your-api-secret \
-- npx -y @samik081/mcp-komodo
# Using Docker
claude mcp add --transport stdio komodo \
--env KOMODO_URL=https://komodo.example.com \
--env KOMODO_API_KEY=your-api-key \
--env KOMODO_API_SECRET=your-api-secret \
-- docker run --rm -i ghcr.io/samik081/mcp-komodo
# Using remote HTTP (connect to a running Docker container or HTTP server)
claude mcp add --transport http komodo http://localhost:3000
JSON config (works with Claude Code .mcp.json, Claude Desktop claude_desktop_config.json, Cursor .cursor/mcp.json):
{
"mcpServers": {
"komodo": {
"command": "npx",
"args": ["-y", "@samik081/mcp-komodo"],
"env": {
"KOMODO_URL": "https://komodo.example.com",
"KOMODO_API_KEY": "your-api-key",
"KOMODO_API_SECRET": "your-api-secret"
}
}
}
}
Docker (stdio):
{
"mcpServers": {
"komodo": {
"command": "docker",
"args": ["run", "--rm", "-i",
"-e", "KOMODO_URL=https://komodo.example.com",
"-e", "KOMODO_API_KEY=your-api-key",
"-e", "KOMODO_API_SECRET=your-api-secret",
"ghcr.io/samik081/mcp-komodo"
]
}
}
}
Remote MCP (connect to a running Docker container or HTTP server):
{
"mcpServers": {
"komodo": {
"type": "streamable-http",
"url": "http://localhost:3000"
}
}
}
Access Tiers
Control which tools are available using the KOMODO_ACCESS_TIER environment variable:
| Tier | Tools | Description |
|---|---|---|
full (default) | 53 | Read, execute, and write -- full control |
read-execute | 52 | Read and execute -- no resource creation/deletion via write tool |
read-only | 36 | Read only -- safe for exploration, no state changes |
Tier details:
- full: All 53 tools. Includes
komodo_write_resourcefor creating, updating, and deleting Komodo resources. - read-execute: 52 tools. All read tools plus execute tools (deploy, pull, lifecycle, run, etc.). The
komodo_write_resourcetool is hidden. - read-only: 36 tools. List, get, logs, inspect, stats, summaries, and operation history only. All execute and write tools are hidden.
Tools that are not available in your tier are not registered with the MCP server. They will not appear in your AI tool's tool list, keeping the context clean.
Set KOMODO_ACCESS_TIER to read-only, read-execute, or full (default: full).
Environment Variables
| Variable | Required | Default | Description |
|---|---|---|---|
KOMODO_URL | Yes | -- | URL of your Komodo Core instance |
KOMODO_API_KEY | Yes | -- | API key for authentication |
KOMODO_API_SECRET | Yes | -- | API secret for authentication |
KOMODO_ACCESS_TIER | No | full | Access tier: read-only, read-execute, or full |
KOMODO_CATEGORIES | No | (all) | Comma-separated category allowlist (e.g., servers,stacks,builds) |
KOMODO_TOOL_BLACKLIST | No | (none) | Comma-separated list of tool names to exclude (e.g., komodo_destroy_stack) |
KOMODO_TOOL_WHITELIST | No | (none) | Comma-separated list of tool names to force-include, bypassing access tier and category filters |
DEBUG | No | false | Enable debug logging to stderr |
MCP_TRANSPORT | No | stdio | Transport mode: stdio (default) or http |
MCP_PORT | No | 3000 | HTTP server port (only used when MCP_TRANSPORT=http) |
MCP_HOST | No | 0.0.0.0 | HTTP server bind address (only used when MCP_TRANSPORT=http) |
MCP_EXCLUDE_TOOL_TITLES | No | false | Set true to omit tool titles from registration (saves tokens) |
Generate API keys in the Komodo UI under Settings > API Keys.
Available Categories
servers, stacks, deployments, containers, builds, repos, procedures, actions, builders, alerters, resource-syncs, updates, write
Tools
mcp-komodo provides 53 tools organized by category. Each tool's Access column shows the minimum tier required: read-only (available in all tiers), read-execute (requires read-execute or full), or full (requires full tier only). The Hints column shows tool behavior: read-only (no state changes), destructive (modifies existing state), idempotent (same result if called twice).
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_servers | List all servers with status and region | read-only | read-only, idempotent |
komodo_get_server | Get server configuration, status, and action state | read-only | read-only, idempotent |
komodo_get_server_stats | Get CPU, memory, disk usage, and load averages | read-only | read-only, idempotent |
komodo_get_server_info | Get OS details, hardware info, and running processes | read-only | read-only, idempotent |
komodo_inspect_docker_container | Inspect a Docker container (equivalent to docker inspect) | read-only | read-only, idempotent |
komodo_inspect_docker_image | Inspect a Docker image (equivalent to docker image inspect) | read-only | read-only, idempotent |
komodo_inspect_docker_network | Inspect a Docker network (equivalent to docker network inspect) | read-only | read-only, idempotent |
komodo_inspect_docker_volume | Inspect a Docker volume (equivalent to docker volume inspect) | read-only | read-only, idempotent |
komodo_prune_docker | Prune unused Docker resources on a server | read-execute | destructive, idempotent |
komodo_delete_docker_resource | Delete a specific Docker image, volume, or network | read-execute | destructive |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_stacks | List all stacks with state, server, and service count | read-only | read-only, idempotent |
komodo_get_stack | Get stack configuration, services, and action state | read-only | read-only, idempotent |
komodo_list_stack_services | List services in a stack with image, container state, and update availability | read-only | read-only, idempotent |
komodo_get_stacks_summary | Get aggregate counts of all stacks by state | read-only | read-only, idempotent |
komodo_get_stack_log | Get logs from stack services, with optional search | read-only | read-only, idempotent |
komodo_inspect_stack_container | Inspect a container for a specific service in a stack | read-only | read-only, idempotent |
komodo_deploy_stack | Deploy or redeploy a stack | read-execute | destructive |
komodo_pull_stack | Pull latest images without redeploying (docker compose pull) | read-execute | idempotent |
komodo_stack_lifecycle | Start, stop, restart, pause, or unpause a stack | read-execute | destructive |
komodo_destroy_stack | Permanently destroy a stack | read-execute | destructive |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_deployments | List all deployments with state, image, and server | read-only | read-only, idempotent |
komodo_get_deployment | Get deployment configuration, container status, and action state | read-only | read-only, idempotent |
komodo_get_deployments_summary | Get aggregate counts of all deployments by state | read-only | read-only, idempotent |
komodo_get_deployment_log | Get container logs, with optional search | read-only | read-only, idempotent |
komodo_inspect_deployment_container | Inspect the container for a deployment (equivalent to docker inspect) | read-only | read-only, idempotent |
komodo_deploy_deployment | Deploy with latest image and configuration | read-execute | destructive |
komodo_pull_deployment | Pull latest image without redeploying (docker pull) | read-execute | idempotent |
komodo_deployment_lifecycle | Start, stop, restart, pause, or unpause a deployment | read-execute | destructive |
komodo_destroy_deployment | Permanently destroy a deployment | read-execute | destructive |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_get_container_log | Get logs from any Docker container on a server | read-only | read-only, idempotent |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_builds | List all build configurations with version info | read-only | read-only, idempotent |
komodo_get_build | Get build configuration, builder, and action state | read-only | read-only, idempotent |
komodo_run_build | Run a build to create a Docker image | read-execute | — |
komodo_cancel_build | Cancel a running build | read-execute | destructive, idempotent |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_repos | List all repos with URL, server, and state | read-only | read-only, idempotent |
komodo_get_repo | Get repo configuration, branch, and action state | read-only | read-only, idempotent |
komodo_repo_clone_pull | Clone or pull a repo on its target server | read-execute | destructive |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_procedures | List all procedures with state | read-only | read-only, idempotent |
komodo_get_procedure | Get procedure stages, operations, and action state | read-only | read-only, idempotent |
komodo_run_procedure | Run a procedure (executes all stages) | read-execute | destructive |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_actions | List all actions with state | read-only | read-only, idempotent |
komodo_get_action | Get action configuration and action state | read-only | read-only, idempotent |
komodo_run_action | Run a custom TypeScript/Deno action | read-execute | destructive |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_builders | List all builders with type | read-only | read-only, idempotent |
komodo_get_builder | Get builder type, server configuration, and state | read-only | read-only, idempotent |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_alerters | List all alerters with type | read-only | read-only, idempotent |
komodo_get_alerter | Get alerter endpoint type, configuration, and status | read-only | read-only, idempotent |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_resource_syncs | List all resource syncs with state and repo info | read-only | read-only, idempotent |
komodo_get_resource_sync | Get sync configuration, managed resources, and state | read-only | read-only, idempotent |
komodo_trigger_sync | Trigger a GitOps sync from the Git repo | read-execute | destructive |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_list_updates | List operation history with filters for resource type, target, operation, and success | read-only | read-only, idempotent |
komodo_get_update | Get full operation details including logs with stdout/stderr for each stage | read-only | read-only, idempotent |
| Tool | Description | Access | Hints |
|---|---|---|---|
komodo_write_resource | Create, update, or delete any Komodo resource | full | destructive |
Verify It Works
After configuring your MCP client, ask your AI assistant:
"What servers are connected to Komodo?"
If the connection is working, the assistant will call komodo_list_servers and return your servers with their current state and region.
Usage Examples
Once configured, ask your AI tool questions in natural language:
-
"List all my servers and their status" -- calls
komodo_list_serversto show every server with its current state and region. -
"What's the CPU and memory usage on server prod-01?" -- calls
komodo_get_server_statsto show real-time resource utilization. -
"Show me the logs from the production stack" -- calls
komodo_get_stack_logto retrieve recent log output from all services in the stack. -
"Deploy the frontend stack" -- calls
komodo_deploy_stackto redeploy the stack with its current configuration. -
"Why did the frontend stack deploy fail?" -- calls
komodo_list_updatesto find the failed deploy, thenkomodo_get_updateto show the full logs with stdout/stderr. -
"Pull the latest images for the monitoring stack" -- calls
komodo_pull_stackto download updated images without redeploying. -
"Create a new deployment called api-staging with image myapp:latest" -- calls
komodo_write_resourceto create a new Deployment resource in Komodo.
Troubleshooting
Connection refused
Check that KOMODO_URL is correct and that Komodo Core is reachable from where the MCP server is running. The server validates the connection on startup, so if it started successfully, the URL was valid at that time.
Invalid credentials / 401 Unauthorized
Verify your API key and secret are correct. Check that the key has not been revoked or expired in the Komodo UI under Settings > API Keys.
Tools not showing up
Check your access tier setting. In read-only mode, only 36 tools are registered. In read-execute mode, 52 tools are registered. Use full (or omit KOMODO_ACCESS_TIER) for all 53 tools. Check KOMODO_CATEGORIES -- only tools in listed categories are registered. Also verify the server started without errors by checking stderr output.
Development
# Install dependencies
npm install
# Build the project
npm run build
# Run in development mode (auto-reload)
npm run dev
# Open the MCP Inspector for interactive testing
npm run inspect
License
常见问题
Komodo MCP Server 是什么?
Manage Komodo through AI assistants
相关 Skills
MCP构建
by anthropics
聚焦高质量 MCP Server 开发,覆盖协议研究、工具设计、错误处理与传输选型,适合用 FastMCP 或 MCP SDK 对接外部 API、封装服务能力。
✎ 想让 LLM 稳定调用外部 API,就用 MCP构建:从 Python 到 Node 都有成熟指引,帮你更快做出高质量 MCP 服务器。
Slack动图
by anthropics
面向Slack的动图制作Skill,内置emoji/消息GIF的尺寸、帧率和色彩约束、校验与优化流程,适合把创意或上传图片快速做成可直接发送的Slack动画。
✎ 帮你快速做出适配 Slack 的动图,内置约束规则和校验工具,少踩上传与播放坑,做表情包和演示都更省心。
MCP服务构建器
by alirezarezvani
从 OpenAPI 一键生成 Python/TypeScript MCP server 脚手架,并校验 tool schema、命名规范与版本兼容性,适合把现有 REST API 快速发布成可生产演进的 MCP 服务。
✎ 帮你快速搭建 MCP 服务与后端 API,脚手架完善、扩展顺手,尤其适合想高效验证服务能力的开发者。
相关 MCP Server
Slack 消息
编辑精选by Anthropic
Slack 是让 AI 助手直接读写你的 Slack 频道和消息的 MCP 服务器。
✎ 这个服务器解决了团队协作中需要 AI 实时获取 Slack 信息的痛点,特别适合开发团队让 Claude 帮忙汇总频道讨论或发送通知。不过,它目前只是参考实现,文档有限,不建议在生产环境直接使用——更适合开发者学习 MCP 如何集成第三方服务。
by netdata
io.github.netdata/mcp-server 是让 AI 助手实时监控服务器指标和日志的 MCP 服务器。
✎ 这个工具解决了运维人员需要手动检查系统状态的痛点,最适合 DevOps 团队让 Claude 自动分析性能数据。不过,它依赖 NetData 的现有部署,如果你没用过这个监控平台,得先花时间配置。
by d4vinci
Scrapling MCP Server 是专为现代网页设计的智能爬虫工具,支持绕过 Cloudflare 等反爬机制。
✎ 这个工具解决了爬取动态网页和反爬网站时的头疼问题,特别适合需要批量采集电商价格或新闻数据的开发者。不过,它依赖外部浏览器引擎,资源消耗较大,不适合轻量级任务。