Komodo 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., "@Komodo MCP Serverlist all servers"
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.
Komodo MCP Server
An MCP (Model Context Protocol) server for interacting with the Komodo Client API, built with FastMCP.
Overview
This MCP server provides a comprehensive interface to the Komodo API, allowing you to manage deployments, builds, stacks, servers, and execute commands through MCP-compatible clients. It exposes all major Komodo API operations as MCP tools.
Related MCP server: Promethean OS MCP
Features
Complete API Coverage: Supports all Komodo API modules (auth, user, read, write, execute, terminal)
Type-Safe: Built with Pydantic for request/response validation
Error Handling: Comprehensive error handling with clear error messages
Flexible Configuration: Supports client-provided configuration or environment variables
Docker Support: Ready-to-use Docker containerization
FastMCP Integration: Built on FastMCP for reliable MCP protocol handling
Installation
Prerequisites
Python 3.12 or later
Access to a Komodo instance
Komodo API credentials (API key and secret)
Install Dependencies
pip install -e .Or install dependencies directly:
pip install fastmcp httpx pydantic python-dotenvConfiguration
The server supports two configuration methods:
Method 1: Client-Provided Configuration (Recommended)
Provide configuration during MCP server initialization. This is the preferred method as it keeps credentials out of environment variables.
MCP Client Configuration Example:
{
"mcpServers": {
"komodo": {
"command": "python",
"args": ["-m", "komodo_mcp.main"],
"initializationOptions": {
"komodo_address": "https://komodo.example.com",
"komodo_api_key": "your_api_key",
"komodo_api_secret": "your_api_secret"
}
}
}
}Alternative parameter names (also supported):
addressinstead ofkomodo_addressapi_keyinstead ofkomodo_api_keyapi_secretinstead ofkomodo_api_secret
Method 2: Environment Variables (Fallback)
If client-provided configuration is not available, the server will fall back to environment variables.
Create a .env file in the project root (or copy from .env.example):
cp .env.example .envEdit .env with your Komodo credentials:
KOMODO_ADDRESS=https://komodo.example.com
KOMODO_API_KEY=your_api_key_here
KOMODO_API_SECRET=your_api_secret_hereEnvironment Variables:
KOMODO_ADDRESS(required): Base URL of your Komodo instance (e.g.,https://komodo.example.com)KOMODO_API_KEY(required): Your Komodo API keyKOMODO_API_SECRET(required): Your Komodo API secret
You can obtain API credentials from the Komodo UI Settings page.
Configuration Priority:
Client-provided initialization options (highest priority)
Environment variables (fallback)
Usage
Running the Server Locally
The server runs using stdio transport (standard for MCP):
python -m komodo_mcp.mainOr use the installed script:
komodo-mcpRunning with Docker
Build the Docker Image
docker build -f docker/Dockerfile -t komodo-mcp .Run the Container
With environment variables:
docker run -it --rm \
-e KOMODO_ADDRESS=https://komodo.example.com \
-e KOMODO_API_KEY=your_api_key \
-e KOMODO_API_SECRET=your_api_secret \
komodo-mcpWith docker-compose:
# Set environment variables in .env file or export them
export KOMODO_ADDRESS=https://komodo.example.com
export KOMODO_API_KEY=your_api_key
export KOMODO_API_SECRET=your_api_secret
docker-compose upWith client-provided configuration:
The Docker container can be used with client-provided configuration. Configure your MCP client to connect to the Docker container:
{
"mcpServers": {
"komodo": {
"command": "docker",
"args": [
"run", "-i", "--rm",
"komodo-mcp"
],
"initializationOptions": {
"komodo_address": "https://komodo.example.com",
"komodo_api_key": "your_api_key",
"komodo_api_secret": "your_api_secret"
}
}
}
}MCP Client Configuration
Local Installation:
{
"mcpServers": {
"komodo": {
"command": "python",
"args": ["-m", "komodo_mcp.main"],
"initializationOptions": {
"komodo_address": "https://komodo.example.com",
"komodo_api_key": "your_api_key",
"komodo_api_secret": "your_api_secret"
}
}
}
}Docker Installation:
{
"mcpServers": {
"komodo": {
"command": "docker",
"args": [
"run", "-i", "--rm",
"komodo-mcp"
],
"initializationOptions": {
"komodo_address": "https://komodo.example.com",
"komodo_api_key": "your_api_key",
"komodo_api_secret": "your_api_secret"
}
}
}
}Available Tools
Authentication
komodo_login: Login to Komodo and obtain authentication token
User Management
komodo_list_api_keys: List all API keys for the current userkomodo_create_api_key: Create a new API keykomodo_delete_api_key: Delete an API key
Read Operations
komodo_get_deployment: Get detailed information about a deploymentkomodo_list_deployments: List all deploymentskomodo_get_build: Get detailed information about a buildkomodo_list_builds: List all buildskomodo_get_stack: Get detailed information about a stackkomodo_list_stacks: List all stackskomodo_get_server: Get detailed information about a serverkomodo_list_servers: List all servers
Write Operations
komodo_create_deployment: Create a new deploymentkomodo_update_deployment: Update an existing deploymentkomodo_delete_deployment: Delete a deploymentkomodo_create_build: Create a new buildkomodo_update_build: Update an existing buildkomodo_delete_build: Delete a buildkomodo_create_stack: Create a new stackkomodo_update_stack: Update an existing stackkomodo_delete_stack: Delete a stackkomodo_create_server: Create a new serverkomodo_update_server: Update an existing serverkomodo_delete_server: Delete a server
Execute Operations
komodo_run_build: Execute/run a buildkomodo_run_deployment: Execute/run a deploymentkomodo_stop_build: Stop a running buildkomodo_stop_deployment: Stop a running deployment
Terminal Operations
komodo_execute_command: Execute a command on a server via terminal
Examples
List All Deployments
# Using an MCP client
result = await client.call_tool("komodo_list_deployments")
print(result)Create a Deployment
config = {
"name": "my-deployment",
"build": "build-id-here",
# ... other deployment config
}
result = await client.call_tool("komodo_create_deployment", {"config": config})
print(result)Run a Build
result = await client.call_tool("komodo_run_build", {
"build": "build-id-here",
"options": {
"environment": "production"
}
})
print(result)Execute a Command on a Server
result = await client.call_tool("komodo_execute_command", {
"server": "server-id-here",
"command": "docker ps",
"options": {
"timeout": 30
}
})
print(result)Error Handling
The server provides comprehensive error handling:
KomodoConfigError: Raised when configuration is invalid or missing
KomodoAPIError: Raised when Komodo API returns an error (includes error message and traceback)
KomodoConnectionError: Raised when connection to Komodo API fails
All errors are properly formatted and include helpful error messages.
Development
Project Structure
komodo-mcp/
├── src/
│ └── komodo_mcp/
│ ├── __init__.py
│ ├── main.py # Entry point
│ ├── server.py # FastMCP server with all tools
│ ├── client.py # Komodo HTTP client
│ ├── config.py # Configuration management
│ ├── errors.py # Custom exceptions
│ ├── models.py # Pydantic models
│ └── tools/ # Tool modules
│ ├── __init__.py
│ ├── auth.py
│ ├── user.py
│ ├── read.py
│ ├── write.py
│ ├── execute.py
│ └── terminal.py
├── tests/ # Test files
│ └── __init__.py
├── docker/
│ └── Dockerfile # Docker image definition
├── docker-compose.yml # Docker Compose configuration
├── .dockerignore # Docker ignore patterns
├── pyproject.toml # Project configuration
├── .env.example # Environment variable template
├── .gitignore
└── README.mdRunning Tests
pytestDocker Development
For development with Docker, you can mount the source code:
# In docker-compose.yml, uncomment the volumes section:
volumes:
- ./src:/app/src:roThen rebuild and run:
docker-compose up --buildDocker Details
Image Size Optimization
The Docker image uses Python 3.12-slim for a smaller footprint. The image includes:
Python 3.12 runtime
Project dependencies
Non-root user for security
Optimized layer caching
Security Considerations
Runs as non-root user (
komodo)No unnecessary packages installed
Environment variables can be provided at runtime
Supports client-provided configuration (no secrets in image)
MCP Protocol Support
MCP servers use stdio transport, so:
No ports need to be exposed
Communication happens via stdin/stdout
Works seamlessly with Docker's stdio support
License
This project is licensed under the same license as the Komodo Client API.
References
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/Thdahwache/komodo-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server