An easy mcp deployment framework
Project description
khivemcp
khivemcp simplifies building complex, configuration-driven MCP
(Model-Context Protocol) services in Python. It acts as a smart wrapper around
the high-performance FastMCP server, enabling you to define your service's
tools and structure using simple Python classes, decorators, and configuration
files.
What is khivemcp?
Building services that implement the Model-Context Protocol (MCP) often requires handling server setup, tool registration according to the protocol, configuration management, and context passing. khivemcp streamlines this:
- Define Logic: Implement your tools or model interactions as methods within standard Python classes (Service Groups).
- Decorate Tools: Mark methods you want to expose as MCP tools using the
simple
@khivemcp.operationdecorator. khivemcp handles registering them correctly with the underlying server. - Configure Structure: Define which group classes to load and how to name their toolsets (operations in MCP terms) using YAML or JSON files.
- Run: Use the
khivemcpcommand-line tool to load your configuration and instantly run a fully featured FastMCP server implementing MCP, with all your tools registered and ready to interact.
khivemcp manages the dynamic loading, instantiation, correct MCP tool registration, and server lifecycle, letting you focus on implementing the specific tools and logic your MCP service needs to provide.
Features
- 🚀 Configuration-Driven: Define service structure, group instances, and MCP tool naming declaratively via YAML or JSON.
- ✨ Decorator-Based Tools: Expose
asyncmethods as MCP tools/operations using the intuitive@khivemcp.operationdecorator. - 📦 Dynamic Loading: Service group classes are loaded dynamically based on
your configuration (
class_path), promoting modularity for different toolsets. - 🛡️ Schema Validation: Leverage Pydantic schemas (
@operation(schema=...)) for automatic validation of MCP operation inputs and clearer tool interfaces. - ⚙️ FastMCP Integration: Built directly on top of the efficient
FastMCPlibrary, which handles the core MCP server logic and protocol communication. - 📄 Stateful Tool Groups: Group classes are instantiated, allowing tools (operations) within a group instance to maintain state across calls if needed.
- 🔧 Configurable Instances: Optionally pass custom configuration dictionaries from your config file to your group class instances during initialization.
Installation
Ensure you have Python 3.10+ and uv (or pip) installed.
uv venv
source .venv/bin/activate
uv pip install khivemcp
Quick Start
Let's create a very simple "Greeter" service and configure a client for it. An
operation decorated function must be async and must only take one parameter:
request (which can be None if no input is needed)
-
Create a Service Group Class (
greeter.py):# file: greeter.py from khivemcp import operation, ServiceGroup from pydantic import BaseModel # Optional: Define an input schema using Pydantic class GreetInput(BaseModel): name: str class GreeterGroup(ServiceGroup): """A very simple group that offers greetings.""" @operation(name="hello", description="Says hello to the provided name.", schema=GreetInput) async def say_hello(self, *, request: GreetInput) -> dict: """Returns a personalized greeting.""" return {"message": f"Hello, {request.name}!"} @operation(name="wave") # Takes no input async def wave_hand(self, *, request=None) -> dict: """Returns a simple wave message.""" return {"action": "*waves*"}
-
Create an khivemcp Configuration File (
greeter.json):{ "name": "greeter", "class_path": "greeter:GreeterGroup", "description": "A simple greeting service." }
(This tells khivemcp to load the
GreeterGroupclass fromgreeter.pyand give its tools the prefixgreeter.) -
Add the khivemcp Server to MCP client:
{ "mcpServers": { "data-processor": { "command": "uv", "args": [ "run", "python", "-m", "khivemcp.cli", "absolute/path/to/your_group.json" ] } } }
(The server starts, listening via stdio by default, and makes the
greeter.hello and greeter.wave MCP operations available.)
This quick start now shows the full loop: defining the service with khivemcp, running it, configuring a standard MCP client to connect to it, and interacting.
Configuration
khivemcp uses configuration files (YAML or JSON) to define services.
GroupConfig: Defines a single group instance (likegreeter.jsonabove). Requiresname(MCP tool prefix) andclass_path.ServiceConfig: Defines a service composed of multipleGroupConfiginstances (using YAML is often clearer for this). Allows building complex services.
(Refer to the docs/ directory for detailed configuration options.)
Creating Service Groups
Implement logic in Python classes and use @khivemcp.operation on async def
methods to expose them as MCP tools (operations). Optionally use Pydantic
schemas for input validation.
(Refer to the docs/ directory for guides on creating groups, using schemas,
and accessing configuration.)
Examples
Under examples
Search Group Example
To use the search group example, you must have EXA_API_KEY and
PERPLEXITY_API_KEY environment variables set, in your .env file or in your
environment.
DO NOT EVER SAVE API KEY IN CONFIG FILE
if you haven't already, install the required dependencies
uv pip install "khivemcp[examples]"
then add the following to your mcpServers in your MCP client configuration:
{
"mcpServers": {
"search-service": {
"command": "absolute_path_to/.venv/bin/python",
"args": [
"-m",
"khivemcp.cli",
"absolute_path_to/examples/config/search_group_config.json"
],
"timeout": 300,
"alwaysAllow": []
}
}
}
Contributing
Contributions to the core khivemcp library are welcome! Please read the
Development Style Guide (dev_style.md) before starting.
It contains essential information on coding standards, testing, and the
contribution workflow.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgements
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file khivemcp-1.1.0.tar.gz.
File metadata
- Download URL: khivemcp-1.1.0.tar.gz
- Upload date:
- Size: 184.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
766cd0244d94819533e7f464fb036a27e98f7b6c4c3100843c545f6bcbd3488c
|
|
| MD5 |
8149c083f0303a4b0c2ee55d09b42480
|
|
| BLAKE2b-256 |
94330c5bd800f483658e6605d38347ce53cd1cd9474df23b17c0bb049b0f5afc
|
File details
Details for the file khivemcp-1.1.0-py3-none-any.whl.
File metadata
- Download URL: khivemcp-1.1.0-py3-none-any.whl
- Upload date:
- Size: 23.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a06ff7b6120e3730cf4fc1f35e024914529270771a939b142f3e5ec354cdf9b0
|
|
| MD5 |
181bd7817cbd09f33e1a42ac588f36fc
|
|
| BLAKE2b-256 |
727eaaef05cfb1da5eee039c335f91e40038a3bb15ea41945ad4d358e7eae02f
|