Add your description here
Project description
EasyMCP
EasyMCP is a complete rewrite of the model context protocol (MCP) in Python.
Installation
uv add easymcp
Usage
The high level API exposes a ClientManager class that can be used to manage multiple MCP servers.
import asyncio
from easymcp.client.ClientManager import ClientManager
from easymcp.client.transports.stdio import StdioServerParameters
mgr = ClientManager()
searxng = StdioServerParameters(
command="uvx",
args=["mcp-searxng"],
)
timeserver = StdioServerParameters(
command="uvx",
args=["mcp-timeserver"],
)
servers = {
"searxng": searxng,
"timeserver": timeserver,
}
async def main():
# initialize the client manager
await mgr.init(servers=servers)
# list servers
print(mgr.list_servers())
# remove a server
await mgr.remove_server("searxng")
# add a server
await mgr.add_server("searxng", searxng)
# list tools - these are namespaced by server name automatically
# {server name}.{tool name}
print(await mgr.list_tools())
# call tool
print(await mgr.call_tool("timeserver.get-current-time", {}))
# list resources - these are namespaced by server name automatically
# mcp-{server name}+{resource uri}
print(await mgr.list_resources())
# read resource
print(await mgr.read_resource("mcp-timeserver+datetime://Africa/Algiers/now"))
await asyncio.Future()
asyncio.run(main())
Core Features
- list tools/resources/prompts caching out of the box
- automatic cache invalidation on tool/resource/prompt change notifications
- out of the box support for parallel requests to servers
- full lifecycle management of servers
- dynamic server addition/removal
- namespaced tools/resources/prompts
- lightweight asyncio native implementation
Why namespace tools?
Namespaced tools remove need to perform a lookup to find the correct tool. This means:
- faster tool calls
- tool calls can be routed across many MCP hosts at scale
- mcp servers do not need globally unique tool names
Why namespace resources?
Resources are namespaced in a way that makes it easy to make a resource URI to a specific server. You can:
- check if a URL needs to be resolved via mcp by checking if it starts with
mcp - check what server to resolve the URI with
- ingest resources into a search system like elastic search without having to store metadata about the server
- completely eliminate the need to map URIs to servers via a database or lookup table
Comparison of classes to other MCP libraries
| easyMCP | modelcontextprotocol/python-sdk |
|---|---|
| ClientManager | |
| ClientSession | ClientSession |
| StdioTransport | stdio_client |
License
This project is licensed under the MIT License - see the LICENSE file for details.
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 easymcp-0.2.0.tar.gz.
File metadata
- Download URL: easymcp-0.2.0.tar.gz
- Upload date:
- Size: 21.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
edfd994de512dfc88a0c80540f1113720b8e83d8e7e199a458ae1a7edd2232e7
|
|
| MD5 |
ba2d1d932da07cffe144e84063b7898e
|
|
| BLAKE2b-256 |
8bc4e349d90683d58a54799c25edaee6016912ab8b6390d4b60f0e8f3143de1b
|
File details
Details for the file easymcp-0.2.0-py3-none-any.whl.
File metadata
- Download URL: easymcp-0.2.0-py3-none-any.whl
- Upload date:
- Size: 20.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f2eb1ee9e2d367958886bc399bf23f47eab071b1a4c14e4320889f10c31799a0
|
|
| MD5 |
e590ed230f29e48df64783a4e0e15d5a
|
|
| BLAKE2b-256 |
cd0c2e2e2476b52d8fd47e780f02d6ca4ea79433d90779af9466280a8599961d
|