Agent+MCP 开发范式

本文主体是高大伟老师在datawhale的宣讲,精练易懂。

辅以一些本人的看法,希望各位大佬一起交流指正。

本人的代码实践

https://github.com/ceilf6/word-MCP-agent/commit/45c7df3908be412da5e362d6da011ab530a56a58

  • 传统智能体架构

    Agent = Model + Context + Tools

    现在 Tools → MCP 进行规范

  • MCP 改变了什么

    • 工具构建过程
      1. 将工具逻辑封装为函数
      2. 面向智能体构建提示:介绍工具用处,如何使用,注意事项
    • MCP 改变了分发逻辑,如地图API、模型服务提供新的发布渠道,且使用和构建新工具的难度降低

实践

AgentScope 1.0 with MCP

  1. 连接高德 MCP Server
  2. 创建 ReAct - 思考+行动的循环
  3. 对话

Toolkit 在 MCP 中类似于一个工具包

在实际过程中会碰到模型将用户需求复杂化的问题

  1. 幻觉
    优化 prompt"不要做任何假设"
  2. 参数结构化

MCP 中有 隐藏的SOP (类似RAG)

将用户的非结构化文本信息转换的过程中需要一个结构化改写

(改进 word-MCP-agent :64964fc86909c14a0646463196c165a58ca9736e25bf287b509617af38e76d70a4570d19c8f49da9

  • 问题:坐标误差

MCP质量控制

智能体和MCP之间的灰色地带:MCP工具精度、能力范围、是否有隐含条件/规则/SOP

软件开发的SDK也是分离的,不也有类似问题吗?

但是,我们对LLM有更高的期待,期待其自主性,加剧了MCP质量控制的需求

AgentScope

显式操控 client 的生命周期

可以直接通过 client.get_callable_function(func_name=" ") 直接将远端的函数拿到,进行二次开发或约束、逻辑封装

多个 MCP Server 的 prompt 等等非常冗杂,可以通过

多个 Agent 每个负责一个 MCP Server 实现解耦

但是该如何处理多个 Agent 的内部关系?

需要一个优雅的、简洁的

解决方案

组管理:工具组(多个方向不同的工具) - groupName

⇒ 元工具:需要什么方向工具就去激活然后配备具体的工具

展望

工具不会是一个孤立的组成部分

  • 模型训练
  • 自我学习、演化
  • 长期记忆

QA

  1. Q: 目前开发框架是否和需求挂钩

    A: 肯定的,开发效率&开发效果

  2. Q: mcp函数优化的目标是优化mcp返回结构?

    A: 不一定,system-prompt的角度、或者是组合这样的深度加工

  3. schema: tools_RAG ,目前 chatbot 动态添加 mcp servser ,这可能会导致 content 的超标

  4. Q: 从回答质量和延迟方面考虑,写好 sys_prompt 是不是 Function Calling 比 ReAct 更好?

    A: 不一定。ReAct 优点在于可交互性,用户的描述可能不准确,更需要 ReAct 多轮采集

相关推荐
草帽lufei1 天前
Prompt Engineering基础实践:角色设定/约束条件等技巧
openai·agent
贾维思基1 天前
告别RPA和脚本!视觉推理Agent,下一代自动化的暴力解法
人工智能·agent
程序猿DD1 天前
Anthropic 如何评估 AI Agent
agent
饭勺oO1 天前
AI 编程配置太头疼?ACP 帮你一键搞定,再也不用反复折腾!
ai·prompt·agent·acp·mcp·skills·agent skill
AGI杂货铺1 天前
零基础也能快速搭建的Deep Agents
ai·langchain·llm·agent·deepagent
AlienZHOU1 天前
MCP 是最大骗局?Skills 才是救星?
agent·mcp·vibecoding
Glink2 天前
从零开始编写自己的AI账单Agent
前端·agent·ai编程
进阶的鱼2 天前
一文助你了解Langchain
python·langchain·agent
Linux内核拾遗2 天前
人人都在聊 MCP,它到底解决了什么?
aigc·ai编程·mcp
Study9962 天前
大语言模型的详解与训练
人工智能·ai·语言模型·自然语言处理·大模型·llm·agent