MCP 服务开发到发布

环境

MCP服务开发环境需要Python 3.10+

我推荐使用uv工具管理Python环境 https://docs.astral.sh/uv/

这个创建一下标准的包结构, 还是比较方便

MCP 调试工具 : https://github.com/modelcontextprotocol/inspector

MCP 服务

官方文档: https://modelcontextprotocol.io/quickstart/server

MCP 服务

MCP主要通信方式:

  1. Stdio transport
    • Uses standard input/output for communication
    • Ideal for local processes
  2. Streamable HTTP transport
    • Uses HTTP with optional Server-Sent Events for streaming
    • HTTP POST for client-to-server messages

stdio:通过标准输入输出流传递数据,实现简单,兼容性强,适合本地开发测试。

sse:允许服务器向客户端推送实时更新,单向通信,适用于需要持续数据更新的场景如实时通知。

注:后来阅读文档, SSE的模式已经废弃了, 但还是很多人用

建立项目

mcp_requests % uv init . –package -p 3.13
Initialized project mcp-requests at /Users/xxxxx/Desktop/mcp_requests

mcp_requests % uv add “mcp[cli]”

image.png

简单代码, 帮我简单发一个 http 的 get 和post 这种方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
import json
from typing import Dict, Any, Optional
import httpx
from mcp.server.fastmcp import FastMCP

# Create an MCP server
mcp = FastMCP("HTTP Requests")

@mcp.tool()
def http_get(url: str, headers: Optional[Dict[str, str]] = None) -> str:
"""Make an HTTP GET request"""
try:
with httpx.Client() as client:
response = client.get(url, headers=headers or {})
return json.dumps({
"status_code": response.status_code,
"headers": dict(response.headers),
"content": response.text
}, indent=2)
except Exception as e:
return f"Error: {str(e)}"

@mcp.tool()
def http_post(url: str, data: Optional[Dict[str, Any]] = None, headers: Optional[Dict[str, str]] = None) -> str:
"""Make an HTTP POST request"""
try:
with httpx.Client() as client:
response = client.post(url, json=data, headers=headers or {})
return json.dumps({
"status_code": response.status_code,
"headers": dict(response.headers),
"content": response.text
}, indent=2)
except Exception as e:
return f"Error: {str(e)}"

@mcp.tool()
def http_put(url: str, data: Optional[Dict[str, Any]] = None, headers: Optional[Dict[str, str]] = None) -> str:
"""Make an HTTP PUT request"""
try:
with httpx.Client() as client:
response = client.put(url, json=data, headers=headers or {})
return json.dumps({
"status_code": response.status_code,
"headers": dict(response.headers),
"content": response.text
}, indent=2)
except Exception as e:
return f"Error: {str(e)}"

@mcp.tool()
def http_delete(url: str, headers: Optional[Dict[str, str]] = None) -> str:
"""Make an HTTP DELETE request"""
try:
with httpx.Client() as client:
response = client.delete(url, headers=headers or {})
return json.dumps({
"status_code": response.status_code,
"headers": dict(response.headers),
"content": response.text
}, indent=2)
except Exception as e:
return f"Error: {str(e)}"

def main() -> None:
import asyncio
asyncio.run(mcp.run(transport='stdio'))

if __name__ == "__main__":
main()

尝试本地测试调用, 再 cursor (其他也可以,我只是电脑恰好有, 比较方便) 里面添加服务,

1
2
3
4
5
6
7
8
9
10
11
12
13
{
"mcpServers": {
"request-server-aaddb": {
"name": "request-mcp-server-aaddb",
"type": "stdio",
"description": "AADDb MCP server",
"isActive": true,
"command": "uv",
"args": ["--directory",
"/Users/yi.zhai/Desktop/mcp_requests", "run", "mcp-requests"]
}
}
}

成功启动

image.png

尝试让 AI 调用

image.png

服务成功收到请求, 测试成功, 功能是跑通了

image.png

PyPI 上传步骤总结

安装构建工具

uv add build twine

构建

uv run python -m build

上传

uv run python -m twine upload dist/* -u **token** -p pypi-xxxxxx

成功标志:

image.png

最后尝试一下 ,直接导入使用, 没问题

1
2
3
4
5
6
7
8
9
{
"mcpServers": {
"mcp-request": {
"command": "mcp-request",
"type": "stdio"
}
}
}

image.png

最后文档服务发布到了

https://pypi.org/project/mcp-request/ 大家可以试试