news 2026/6/15 3:42:51

Agno中使用MCP

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Agno中使用MCP

Agno中使用MCP

1 简介

模型上下文协议(MCP)能够通过标准化的接口与外部系统进行交互。使用Agno集成的MCP客户端,可以连接到任何MCP服务器。本文使用Agno连接MCP服务。

参考地址

# MCP服务 https://github.com/modelcontextprotocol/python-sdk # Agno中MCP调用 https://docs.agno.com/basics/tools/mcp/overview

安装MCP和Agno

pip install "mcp[cli]" pip install agno

2 实现MCP服务

MCP服务代码

mcp_server.py

frommcp.server.fastmcpimportFastMCP# 创建MCP,Demo是MCP名字mcp=FastMCP("Demo")# Add an addition tool@mcp.tool(# 默认工具的名称name="add",# 说明title="加法",# 详细描述,大模型解析description="加法",# 是否结构化输出structured_output=None)defadd(a:int,b:int)->int:"""Add two numbers"""print("加法")returna+b# Add a subtraction tool@mcp.tool()defsubtraction(a:int,b:int)->int:"""Add two numbers"""print("减法")returna-b# Add a dynamic greeting resource@mcp.resource("greeting://{name}")defget_greeting(name:str)->str:"""Get a personalized greeting"""returnf"Hello,{name}!"# Add a prompt@mcp.prompt()defgreet_user(name:str,style:str="friendly")->str:"""Generate a greeting prompt"""styles={"friendly":"Please write a warm, friendly greeting","formal":"Please write a formal, professional greeting","casual":"Please write a casual, relaxed greeting",}returnf"{styles.get(style,styles['friendly'])}for someone named{name}."# Run with streamable HTTP transportif__name__=="__main__":# 使用SSE# mcp.run(transport="sse")mcp.run(transport="streamable-http")

输出

3 使用Agno实现MCP客户端

mcp_client.py

importasynciofromtextwrapimportdedentfromagno.agentimportAgentfromagno.models.openaiimportOpenAILikefromagno.tools.mcpimportMCPToolsasyncdefrun_agent(message:str)->None:# 初始化工具# 使用SSE# mcp_tools = MCPTools(# transport="sse",# url="http://127.0.0.1:8000/sse"# )mcp_tools=MCPTools(transport="streamable-http",url="http://127.0.0.1:8000/mcp")# 连接MCPawaitmcp_tools.connect()# 打印工具print(mcp_tools)# 自定义模型model=OpenAILike(# 设置自定义模型名称id="llm-v1",api_key="EMPTY",# 自定模型地址base_url="http://192.168.0.106:8000/v1")try:# 智能体agent=Agent(model=model,tools=[mcp_tools],instructions=dedent("测试"),markdown=True,)# 运行智能体,并打印awaitagent.aprint_response(message,stream=True)finally:# 关闭服务awaitmcp_tools.close()if__name__=="__main__":# 调用加法asyncio.run(run_agent("1加1等多少"))# 调用减法asyncio.run(run_agent("1减1等多少"))

输出

4 使用MCP Inspector

启动服务,第一次会初始化配置。

mcp dev .\mcp_server.py

启动服务界面

MCP Inspector连接界面

MCP Inspector简单使用

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/13 13:04:46

如何高效恢复Godot项目?GDS Decompiler功能与实战指南

如何高效恢复Godot项目?GDS Decompiler功能与实战指南 【免费下载链接】gdsdecomp Godot reverse engineering tools 项目地址: https://gitcode.com/gh_mirrors/gd/gdsdecomp 为什么选择GDS Decompiler进行Godot项目恢复 在Godot引擎开发过程中&#xff0c…

作者头像 李华
网站建设 2026/6/13 13:05:15

三极管多级放大电路耦合方式:原理讲解

以下是对您提供的博文《三极管多级放大电路耦合方式:原理讲解与工程实践分析》的 深度润色与重构版本 。本次优化严格遵循您的全部要求: ✅ 彻底去除AI痕迹,语言更贴近一线工程师真实表达(口语化但不失专业) ✅ 删…

作者头像 李华
网站建设 2026/6/10 16:52:21

未来AI创作模式前瞻:麦橘超然离线部署价值分析

未来AI创作模式前瞻:麦橘超然离线部署价值分析 1. 为什么“离线”正在成为AI图像生成的新刚需 你有没有遇到过这些情况:正要给客户演示一张概念图,网页突然卡在“加载中”;深夜灵感迸发想试几个新风格,却发现API调用…

作者头像 李华
网站建设 2026/6/13 19:25:39

手把手教你完成Arduino安装教程并接入MQTT智能家居

以下是对您提供的博文内容进行 深度润色与结构重构后的技术博客正文 。本次优化严格遵循您的全部要求: ✅ 彻底去除AI痕迹,语言自然、专业、有“人味”——像一位经验丰富的嵌入式工程师在和你面对面分享; ✅ 打破模板化标题(…

作者头像 李华