模型上下文协议(MCP)是一个开放协议, 支持大语言模型(LLM)应用与外部数据源和工具的无缝集成。无论您是构建 AI 驱动的集成开发环境(IDE)、增强聊天界面,还是创建自定义 AI 工作流,MCP 都提供了一种标准化的方式,将大语言模型与所需的上下文连接起来。
本规范定义了权威的协议要求,基于 schema.ts 中的 TypeScript 模式。
有关实现指南和示例,请访问 modelcontextprotocol.io。
本文档中的关键词“MUST”、“MUST NOT”、“REQUIRED”、“SHALL”、“SHALL NOT”、“SHOULD”、“SHOULD NOT”、“RECOMMENDED”、“NOT RECOMMENDED”、“MAY”和“OPTIONAL”应按照 BCP 14 [RFC2119] [RFC8174] 的描述进行解释,且仅当它们以全大写形式出现时适用,如本文所示。
MCP 为应用程序提供了一种标准化的方式,以便:
该协议使用 JSON-RPC 2.0 消息格式在以下组件之间建立通信:
MCP 受到 语言服务器协议 的启发,该协议标准化了在整个开发工具生态系统中添加编程语言支持的方式。类似地,MCP 标准化了如何将额外的上下文和工具集成到 AI 应用生态系统中。
服务器向客户端提供以下功能之一或全部:
客户端可以向服务器提供以下功能:
模型上下文协议通过任意数据访问和代码执行路径启用了强大的功能。这种强大的能力带来了重要的安全性和信任考虑,所有实现者必须认真对待。
用户同意和控制
数据隐私
工具安全
大语言模型采样控制
虽然 MCP 本身无法在协议层面强制执行这些安全原则,但实现者 应该:
探索每个协议组件的详细规范: