当前位置: 首页 > news >正文

MCP 服务开发到发布

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]”

在这里插入图片描述

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

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 asyncioasyncio.run(mcp.run(transport='stdio'))if __name__ == "__main__":main()

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

{"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"]}}
}

成功启动

在这里插入图片描述
在这里插入图片描述

尝试让 AI 调用

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

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

PyPI 上传步骤总结

安装构建工具

uv add build twine

构建

uv run python -m build

上传

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

成功标志:

在这里插入图片描述

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

{"mcpServers": {"mcp-request": {"command": "mcp-request","type": "stdio"}}
}

在这里插入图片描述

最后文档服务发布到了

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

http://www.dtcms.com/a/277646.html

相关文章:

  • 更换docker工作目录
  • MongoDB对接SpringBoot【大数据存储】
  • Hashtable 与 HashMap 的区别笔记
  • 利用DeepSeek证明立体几何题目
  • Flink学习笔记:整体架构
  • Vue 3 动态ref问题
  • 第十五篇:Python操作Excel速成:读写单元格、样式与公式,你的第一个数据自动化脚本!告别手动录入!
  • 002大模型基础知识
  • 多项式运算→复数域FFT→有限域NTT
  • 在上海开发小程序,怎么做出“高级感”?
  • RTDETR融合[CVPR2024]SHViT中的SHSA模块
  • 业务访问控制-ACL与包过滤
  • openeuler使用桥接模式(包括新建虚拟机和已有虚拟机)
  • C语言集成ip2region快速指南
  • java: DDD using oracle 21c
  • 【实证分析】上市公司绿色战略数据集(2000-2023年)
  • 【PTA数据结构 | C语言版】字符串删除操作
  • Mybatis自动创建数据库表,并根据创建的表自动生成Mvc框架基础代码
  • WPS新版Latex公式改为显示样式,防止内嵌缩小
  • 清华北大西工大!具身导航最新综述
  • Git的常用操作
  • MYSQL笔记2
  • NW756NW815美光固态闪存NW821NW828
  • Switch表达式
  • 算法第三十二天--动态规划part01(第九章)
  • 苍穹外卖@RequestBody导错包导致接收不到传入参数
  • Linux锁的概念及线程同步
  • 互斥锁详解(操作系统os)
  • VUE3(二)、路由
  • 时序预测 | Pytorch实现CNN-KAN电力负荷时间序列预测模型