概述
MCP 为应用程序提供了一种标准化的方式来:- 与语言模型共享上下文信息
- 向 AI 系统暴露工具和能力
- 构建可组合的集成和工作流
- 主机:发起连接的 LLM 应用程序
- 客户端:主机应用程序中的连接器
- 服务器:提供上下文和能力的服务
关键细节
基础协议
- JSON-RPC 消息格式
- Stateful connections
- Server and client capability negotiation
Features
Servers offer any of the following features to clients:- Resources: Context and data, for the user or the AI model to use
- Prompts: Templated messages and workflows for users
- Tools: Functions for the AI model to execute
- Sampling: Server-initiated agentic behaviors and recursive LLM interactions
其他工具
- 配置
- 进度跟踪
- 取消
- 错误报告
- 日志记录
安全性和信任与安全
Model Context Protocol 通过任意数据访问和代码执行路径实现了强大的功能。这种强大功能伴随着重要的安全和信任考虑,所有实现者都必须仔细处理。关键原则
-
用户同意和控制
- 用户必须明确同意并理解所有数据访问和操作
- 用户必须保留对共享哪些数据和采取哪些行动的控制权
- 实现者应提供清晰的UI来审查和授权活动
-
数据隐私
- 主机必须在向服务器公开用户数据之前获得明确的
- 主机不得未经用户同意将资源数据传输到其他地方
- 用户数据应通过适当的访问控制进行保护
- 工具安全
- 工具代表任意代码执行,必须谨慎对待。
- 特别是,除非从受信任的服务器获得,否则工具行为的描述(如注释)应被视为不可信。
- 主机必须在调用任何工具之前获得明确的
- 工具代表任意代码执行,必须谨慎对待。
- 用户在授权使用之前应了解每个工具的作用
- LLM采样控制
- 用户必须明确批准任何LLM采样请求
- 用户应控制:
- 是否进行采样
- 将发送的实际提示
- 服务器可以看到哪些结果
- 该协议故意限制服务器对提示的可见性
实现指南
虽然MCP本身无法在协议级别强制执行这些安全原则,但实现者应该:- 在其应用程序中构建强大的同意和授权流程
- 提供安全影响的清晰文档
- 实施适当的访问控制和数据保护
- 在其集成中遵循安全最佳实践
- 在其功能设计中考虑隐私影响