Komodo MCP Server

Komodo MCP Server

A server that provides a comprehensive interface to the Komodo API, enabling management of deployments, builds, stacks, servers, and command execution through MCP-compatible clients.

Category
Visit Server

README

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.

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-dotenv

Configuration

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):

  • address instead of komodo_address
  • api_key instead of komodo_api_key
  • api_secret instead of komodo_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 .env

Edit .env with your Komodo credentials:

KOMODO_ADDRESS=https://komodo.example.com
KOMODO_API_KEY=your_api_key_here
KOMODO_API_SECRET=your_api_secret_here

Environment Variables:

  • KOMODO_ADDRESS (required): Base URL of your Komodo instance (e.g., https://komodo.example.com)
  • KOMODO_API_KEY (required): Your Komodo API key
  • KOMODO_API_SECRET (required): Your Komodo API secret

You can obtain API credentials from the Komodo UI Settings page.

Configuration Priority:

  1. Client-provided initialization options (highest priority)
  2. Environment variables (fallback)

Usage

Running the Server Locally

The server runs using stdio transport (standard for MCP):

python -m komodo_mcp.main

Or use the installed script:

komodo-mcp

Running 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-mcp

With 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 up

With 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 user
  • komodo_create_api_key: Create a new API key
  • komodo_delete_api_key: Delete an API key

Read Operations

  • komodo_get_deployment: Get detailed information about a deployment
  • komodo_list_deployments: List all deployments
  • komodo_get_build: Get detailed information about a build
  • komodo_list_builds: List all builds
  • komodo_get_stack: Get detailed information about a stack
  • komodo_list_stacks: List all stacks
  • komodo_get_server: Get detailed information about a server
  • komodo_list_servers: List all servers

Write Operations

  • komodo_create_deployment: Create a new deployment
  • komodo_update_deployment: Update an existing deployment
  • komodo_delete_deployment: Delete a deployment
  • komodo_create_build: Create a new build
  • komodo_update_build: Update an existing build
  • komodo_delete_build: Delete a build
  • komodo_create_stack: Create a new stack
  • komodo_update_stack: Update an existing stack
  • komodo_delete_stack: Delete a stack
  • komodo_create_server: Create a new server
  • komodo_update_server: Update an existing server
  • komodo_delete_server: Delete a server

Execute Operations

  • komodo_run_build: Execute/run a build
  • komodo_run_deployment: Execute/run a deployment
  • komodo_stop_build: Stop a running build
  • komodo_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.md

Running Tests

pytest

Docker Development

For development with Docker, you can mount the source code:

# In docker-compose.yml, uncomment the volumes section:
volumes:
  - ./src:/app/src:ro

Then rebuild and run:

docker-compose up --build

Docker 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

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured