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

AI学习:什么是MCP,写第一个MCP

什么是MCP?

MCP(Model Context Protocol)是一个开放的协议标准,用于连接AI助手(如Claude、GPT等)与外部工具和数据源。它定义了一套标准化的通信方式,让AI助手能够安全、可靠地调用外部服务。

MCP的核心概念

1. 客户端-服务器架构

  • 客户端:AI助手(如Claude Desktop、VS Code插件等)
  • 服务器:提供工具和资源的外部服务
  • 通信方式:通过标准输入输出进行JSON-RPC 2.0协议通信

2. 传输协议

  • 使用JSON-RPC 2.0作为通信协议
  • 通过stdin/stdout进行数据传输
  • 每行一个JSON对象,以换行符分隔

MCP基本语法规范

1. 初始化请求initialize

{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2024-11-05","capabilities":{"tools":{}},"clientInfo":{"name":"Claude Desktop","version":"1.0.0"}}}

2. 工具列表请求tools/list

{"jsonrpc":"2.0","id":2,"method":"tools/list"}

3. 工具调用请求tools/call

{"jsonrpc":"2.0","id":3,"method":"tools/call","params":{"name":"calculate","arguments":{"expression":"2+3*4"}}}

4. 响应格式

{"jsonrpc":"2.0","id":3,"result":{"content":[{"type":"text","text":"计算结果:14"}]}}

MCP服务器实现要点

1. 必需的方法

  • initialize:服务器初始化
  • tools/list:返回可用工具列表
  • tools/call:执行具体的工具调用

2. 工具定义结构

{"name":"工具名称","description":"工具描述","inputSchema":{"type":"object","properties":{"参数名":{"type":"参数类型","description":"参数描述"}},"required":["必需参数列表"]}}

3. 错误处理

{"jsonrpc":"2.0","id":请求ID,"error":{"code":错误代码,"message":"错误描述"}}

MCP服务器例子

#!/usr/bin/env python3 #-*-coding:utf-8-*-""" 简单的MCP服务器示例 提供基本的计算工具"""importjsonimportsysfromtypingimportDict,Any,List,OptionalclassSimpleMCPServer:"""简单的MCP服务器实现"""def__init__(self):self.tools={"calculate":{"name":"calculate","description":"执行简单的数学计算","inputSchema":{"type":"object","properties":{"expression":{"type":"string","description":"要计算的数学表达式,如 '2+3*4'"}},"required":["expression"]}},}defhandle_request(self,request:Dict[str,Any])->Dict[str,Any]:"""处理MCP请求"""method=request.get("method")ifmethod=="initialize":returnself._handle_initialize(request)elif method=="tools/list":returnself._handle_tools_list(request)elif method=="tools/call":returnself._handle_tools_call(request)else:return{"jsonrpc":"2.0","id":self._get_request_id(request),"error":{"code":-32601,"message":f"未知方法: {method}"}}def_handle_initialize(self,request:Dict[str,Any])->Dict[str,Any]:"""处理初始化请求"""return{"jsonrpc":"2.0","id":self._get_request_id(request),"result":{"protocolVersion":"2024-11-05","capabilities":{"tools":{}},"serverInfo":{"name":"SimpleMCPServer","version":"1.0.0"}}}def_handle_tools_list(self,request:Dict[str,Any])->Dict[str,Any]:"""处理工具列表请求"""return{"jsonrpc":"2.0","id":self._get_request_id(request),"result":{"tools":list(self.tools.values())}}def_handle_tools_call(self,request:Dict[str,Any])->Dict[str,Any]:"""处理工具调用请求"""params=request.get("params",{})tool_name=params.get("name")arguments=params.get("arguments",{})try:iftool_name=="calculate":result=self._calculate(arguments.get("expression",""))else:return{"jsonrpc":"2.0","id":self._get_request_id(request),"error":{"code":-32601,"message":f"未知工具: {tool_name}"}}return{"jsonrpc":"2.0","id":self._get_request_id(request),"result":{"content":[{"type":"text","text":json.dumps(result,ensure_ascii=False,indent=2)}]}}except Exceptionase:return{"jsonrpc":"2.0","id":self._get_request_id(request),"error":{"code":-32603,"message":f"工具执行错误: {str(e)}"}}def_calculate(self,expression:str)->Dict[str,Any]:"""执行数学计算"""try:# 安全的数学表达式计算 allowed_chars=set("0123456789+-*/.() ")ifnotall(cinallowed_charsforcinexpression):raiseValueError("表达式包含不允许的字符")result=eval(expression)return{"expression":expression,"result":result,"type":"number"}except Exceptionase:raiseValueError(f"计算错误: {str(e)}")def_get_request_id(self,request:Dict[str,Any])->Any:"""获取请求ID,如果请求中没有ID则返回默认ID"""if"id"inrequest:returnrequest["id"]else:# 如果请求中没有id,返回一个默认的字符串IDreturn"default-id"defrun(self):"""运行MCP服务器"""print("Simple MCP Server 启动中...",file=sys.stderr)try:forlineinsys.stdin:line=line.strip()ifnot line:continuetry:request=json.loads(line)response=self.handle_request(request)print(json.dumps(response,ensure_ascii=True))sys.stdout.flush()except json.JSONDecodeError:error_response={"jsonrpc":"2.0","id":"default-id","error":{"code":-32700,"message":"解析错误"}}print(json.dumps(error_response,ensure_ascii=False))sys.stdout.flush()except KeyboardInterrupt:print("服务器关闭",file=sys.stderr)if__name__=="__main__":server=SimpleMCPServer()server.run()

简单计算器MCP服务器

本项目中的simple_mcp_server.py是一个完整的MCP服务器示例,包含:

  1. 数学计算工具:执行基本数学表达式
  2. 文本统计工具:分析文本的字符、单词等统计信息
  3. 系统信息工具:获取Python和系统基本信息

可以通过以下方式测试:

# 启动服务器python simple_mcp_server.py# 在另一个终端测试echo'{"jsonrpc":"2.0","id":1,"method":"tools/list"}'|python simple_mcp_server.py

真实cursor上加配置调用即可
{“mcpServers”:{“my-server”:{“command”:“python”,“args”:[“D:/sase-dfx/sase_dfx/9、ai生成/simple_mcp_server.py”],“disabled”:false,“alwaysAllow”:[“calculate”]}}}

http://www.jsqmd.com/news/125412/

相关文章:

  • 【Mol Plant综述精读】植物中的染色质重塑:复合物组成、机制多样性及生物学功能
  • java学习--Math 类常用方法
  • 新人写文必看:如何用【ai生成小说】搞定日更?这篇万字实操干货告诉你
  • PostgreSQL 18 从新手到大师:实战指南 - 1.1 PostgreSQL 18简介
  • 2025年值得尝试的AI论文写作工具,支持LaTeX编辑与自动格式修正
  • 使用树莓派打造语音控制家居的超详细版教程
  • MECE法则,分析问题方法
  • 2025年10款AI论文辅助软件,提供LaTeX模板与精准格式校验功能
  • TensorFlow/Keras模型搭建、训练与保存超详细教程(2025实战版)
  • AI编程工具推荐:根据你的合作模式,寻找最佳“AI伙伴”
  • 适用于嵌入式设备的轻量级framebuffer驱动设计
  • 稳定性进程监控工具
  • Packet Tracer下载步骤详解:适合初学者的系统学习
  • 分享精选文章合集 2025-12-22
  • 零基础理解USB接口引脚功能的通俗解释
  • 2025年热门AI论文生成工具,具备LaTeX兼容性及自动排版优化
  • 【技术教程】Reveal.js 中文使用教程
  • 零基础学Arduino UNO下载:从电脑到开发板的连接详解
  • Touch屏厚度对灵敏度影响:科学分析材料与性能关系
  • 主从复制
  • 2025年AI论文写作平台精选,集成LaTeX支持与智能格式检查
  • 星历解算从参数到指向角的推导
  • BetterNCM插件:重新定义网易云音乐体验
  • 12-22午夜盘思
  • 机械键盘连击终极修复方案:零成本软件解决方案完全指南
  • 机械键盘连击终极修复方案:零成本软件解决方案完全指南
  • Vivado2022.2安装教程:磁盘空间规划与分区建议
  • 个人食物中毒不算意外事故?食用野生蘑菇后保险拒赔怎么办?
  • 5大核心功能解密:让老旧iOS设备重获新生的终极操作指南
  • Calibre-Douban插件:轻松获取豆瓣图书元数据的完整指南