1. 面试题目
请详细解释什么是 MCP(Model Context Protocol) 和 A2A(Agent-to-Agent)协议?它们分别解决了 AI 开发中的什么痛点?在未来的多智能体生态中,这两者扮演着怎样的角色?
2. 知识储备
2.1. MCP (Model Context Protocol) ------ 模型上下文协议
① 本质: 由 Anthropic 提出的一种开放标准,旨在让 AI 模型安全、无缝地接入外部数据源和工具。
② 解决的痛点: 以前每个 AI 应用接入 GitHub、Google Drive 或本地数据库,都要针对不同模型写一套集成的代码。MCP 像是一个 "万能插座",让数据源只需实现一次接口,就能被任何支持 MCP 的模型调用。
③ 核心架构:
- MCP Host: 像 Claude Desktop 这样的应用(用户端)。
- MCP Client: 在 Host 内部,负责与 Server 通信。
- MCP Server: 连接具体的数据源(如 Postgres, Slack)。
2.2. A2A (Agent-to-Agent) 协议 ------ 智能体间通信协议
① 本质: 一套标准化的通信与协作规范,定义了两个独立的 Agent 之间如何交换信息、分发任务和确认结果。
② 解决的痛点: 现在的 Agent 大多是"孤岛"。如果我想让"旅游 Agent"找"财务 Agent"报销,它们之间没有统一的语言。A2A 协议提供了类似人类职场的"沟通黑话"。
③ 核心组件:
- 握手机制: 确认对方能力(你能帮我定酒店吗?)。
- 权限委派: 我授权你访问我的信用卡余额。
- 状态同步: 任务执行到哪一步了?
2.3. MCP vs A2A:核心区别
|---------|-----------------------|---------------------------|
| 维度 | MCP | A2A |
| 关注点 | 人/模型与数据的连接 | 智能体与智能体的协作 |
| 类比 | 为手机充电的 USB-C 接口 | 职场里的 SOP/工作邮件规范 |
| 层级 | 资源层 (Resources/Tools) | 逻辑/社会层 (Society/Logic) |
| 主导者 | Anthropic 等模型厂商 | 智能体框架 (OpenClaw, MetaGPT) |
3. 代码实现
3.1. Python 实现 (模拟 A2A 的任务委派逻辑)
Python 在处理复杂逻辑时更具表达力。
python
class AgentA2A:
def __init__(self, agent_id):
self.agent_id = agent_id
def delegate_task(self, target_agent, task_description):
# 1. 发起 A2A 握手
print(f"[{self.agent_id}] 正在向 [{target_agent.agent_id}] 申请协作...")
# 2. 按照 A2A 协议格式封装任务
payload = {
"protocol_version": "1.0",
"sender": self.agent_id,
"task": task_description,
"callback_url": "http://agent-a/result"
}
return target_agent.receive_task(payload)
# 模拟:财务 Agent 接收 旅游 Agent 的请求
3.2. Node.js 实现 (模拟 MCP Server 端的 Resource 暴露)
Node.js 非常适合作为 MCP Server,利用其丰富的生态连接各种数据库。
javascript
// 模拟一个简单的 MCP Resource Server
const mcpServer = {
resources: {
"file://logs": () => "这里是服务器日志数据...",
"db://users": () => "用户信息:张三, 李四..."
},
// 响应 Client 的读取请求
handleReadResource(uri) {
if (this.resources[uri]) {
return { content: this.resources[uri](), status: "success" };
}
return { status: "error", message: "Resource not found" };
}
};
四、 破局之道
在面试中,用这段话展现你对行业趋势的预判:
回答这两个协议的区别,关键在于理解 "AI 的边界扩张"。
你可以告诉面试官:MCP 是在打通 "AI 与物" 的连接,让数据像自来水一样接入模型;而 A2A 是在打通 "AI 与人/AI" 的连接,构建一个能够自我协同的智能社会。在工程落地时,我会优先采用支持 MCP 的架构来提升数据的流动性,并利用 A2A 的思想设计多智能体系统的通信闭环。未来的 AI 应用不再是单打独斗,而是通过标准化协议交织而成的智能网络。