🚀用MCP为AutoGen开挂接入各种工具和框架!Cline零代码开发MCP Server实现接入LangFlow进行文档问答!利用MCP Server突破平

🚀🚀🚀本篇笔记所对应的视频:www.bilibili.com/video/BV1gd... AutoGen v0.4引入了对Model Context Protocol (MCP) server的支持,这是一项重要的新功能,为AI代理提供了更强大和灵活的工具使用能力。

MCP Server支持

AutoGen v0.4通过autogen_ext.tools.mcp模块提供了对MCP server的支持。这允许用户将MCP兼容的工具集成到AutoGen代理中,主要通过以下两种方式:

  1. Server-Sent Events (SSE) : 通过SseMcpToolAdapter类,可以包装基于HTTP和SSE的MCP工具。
  2. 标准输入/输出 (STDIO) : 使用StdioMcpToolAdapter类,可以包装基于命令行的MCP工具。

集成方法

AutoGen提供了便捷的方法来集成MCP工具:

  1. 使用mcp_server_tools函数可以连接到MCP server并返回所有可用工具的适配器。
  2. 这些适配器可以直接分配给AutoGen代理的工具列表,使代理能够使用这些工具。

优势

支持MCP server为AutoGen带来了以下优势:

  1. 标准化接口: MCP被描述为"AI工具的USB",提供了一种标准化的方式让AI代理发现和使用不同的功能。
  2. 灵活性: 用户可以轻松地将各种MCP兼容工具集成到他们的AutoGen工作流中,包括远程服务、云端工具和Web API。
  3. 可扩展性: 通过简单的配置,可以添加新的MCP server来扩展代理的能力。
  4. 动态工具使用: AutoGen实现了基于字典的灵活方法,使得发现和使用工具变得简单。
  5. 跨语言支持: 这种集成支持不同编程语言构建的代理之间的互操作性。
  6. 模块化和可扩展: 用户可以轻松定制系统,使用可插拔的组件,包括自定义代理、工具、内存和模型。

通过支持MCP server,AutoGen大大增强了其生态系统的开放性和可扩展性,使开发者能够更容易地集成各种工具和服务,从而创建更强大、更灵活的AI代理系统。

🔥LangFlow安装以及Cline提示词

swift 复制代码
# 安装命令
python -m pip install langflow

# 运行
python -m langflow run

## 提示词
show me some examples about Self-Consistency Prompt 

## Cline提示词

请为我开发一个用于文档问答系统的MCP Tool,
要求实现用户能够输入要检索的提示词,然后进行检索,最后获取到检索到结果。
下面是文档问答系统的API交互方式:

### 请求内容如下,其中input_value的值就是用于检索的提示词:
curl -X POST \
    "<http://127.0.0.1:7860/api/v1/run/a8e187bd-44e7-4984-9218-42f63946760b?stream=false>" \
    -H 'Content-Type: application/json'\
    -d '{"input_value": "show me some examples about Self-Consistency Prompt ",
    "output_type": "chat",
    "input_type": "chat",
    "tweaks": {
  "ChatInput-Jrzyb": {},
  "ChatOutput-rzoZb": {},
  "ParseData-hzL7Q": {},
  "File-2Teuj": {},
  "Prompt-ktajI": {},
  "MistralModel-aLZcw": {}
}}'
### 响应内容如下,其中text的值就是检索到的结果:
{"session_id":"a8e187bd-44e7-4984-9218-42f63946760b","outputs":[{"inputs":{"input_value":"show me some examples about Self-Consistency Prompt "},"outputs":[{"results":{"message":{"text_key":"text","data":{"timestamp":"2025-02-22T08:22:24+00:00","sender":"Machine","sender_name":"AI","session_id":"a8e187bd-44e7-4984-9218-42f63946760b","text":"Sure, here are some examples of the Self-Consistency Prompt technique from the document:\n\n1. **Text Generation:**\n   - Task: Generate a product review\n   - Instructions: The review should be consistent with the product information provided in the input\n   - Prompt formula: \"Generate a product review that is consistent with the following product information [insert product information]\"\n\n2. **Text Summarization:**\n   - Task: Summarize a news article\n   - Instructions: The summary should be consistent with the information provided in the article\n   - Prompt formula: \"Summarize the following news article in a way that is consistent with the information provided [insert news article]\"\n\n3. **Text Completion:**\n   - Task: Complete a sentence\n   - Instructions: The completion should be consistent with the context provided in the input\n   - Prompt formula: \"Complete the following sentence in a way that is consistent with the context provided [insert sentence]\"\n\n4. **Fact-checking:**\n   - Task: Check for consistency in a given news article\n   - Input text: \"The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n   - Prompt formula: \"Please ensure the following text is self-consistent: The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n\n5. **Data validation:**\n   - Task: Check for consistency in a given data set\n   - Input text: \"The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n   - Prompt formula: \"Please ensure the following text is self-consistent: The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n\nIn each of these examples, the Self-Consistency Prompt technique is used to ensure that the output generated by the model is consistent with the input provided. This helps to maintain accuracy and relevance in the generated text.","files":[],"error":false,"edit":false,"properties":{"text_color":"","background_color":"","edited":false,"source":{"id":"MistralModel-aLZcw","display_name":"MistralAI","source":"mistral-large-latest"},"icon":"MistralAI","allow_markdown":false,"positive_feedback":null,"state":"complete","targets":[]},"category":"message","content_blocks":[],"id":"876f9dd0-fa96-4ba3-81cc-43e7d2a65cec","flow_id":"a8e187bd-44e7-4984-9218-42f63946760b"},"default_value":"","text":"Sure, here are some examples of the Self-Consistency Prompt technique from the document:\n\n1. **Text Generation:**\n   - Task: Generate a product review\n   - Instructions: The review should be consistent with the product information provided in the input\n   - Prompt formula: \"Generate a product review that is consistent with the following product information [insert product information]\"\n\n2. **Text Summarization:**\n   - Task: Summarize a news article\n   - Instructions: The summary should be consistent with the information provided in the article\n   - Prompt formula: \"Summarize the following news article in a way that is consistent with the information provided [insert news article]\"\n\n3. **Text Completion:**\n   - Task: Complete a sentence\n   - Instructions: The completion should be consistent with the context provided in the input\n   - Prompt formula: \"Complete the following sentence in a way that is consistent with the context provided [insert sentence]\"\n\n4. **Fact-checking:**\n   - Task: Check for consistency in a given news article\n   - Input text: \"The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n   - Prompt formula: \"Please ensure the following text is self-consistent: The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n\n5. **Data validation:**\n   - Task: Check for consistency in a given data set\n   - Input text: \"The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n   - Prompt formula: \"Please ensure the following text is self-consistent: The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n\nIn each of these examples, the Self-Consistency Prompt technique is used to ensure that the output generated by the model is consistent with the input provided. This helps to maintain accuracy and relevance in the generated text.","sender":"Machine","sender_name":"AI","files":[],"session_id":"a8e187bd-44e7-4984-9218-42f63946760b","timestamp":"2025-02-22T08:22:24+00:00","flow_id":"a8e187bd-44e7-4984-9218-42f63946760b","error":false,"edit":false,"properties":{"text_color":"","background_color":"","edited":false,"source":{"id":"MistralModel-aLZcw","display_name":"MistralAI","source":"mistral-large-latest"},"icon":"MistralAI","allow_markdown":false,"positive_feedback":null,"state":"complete","targets":[]},"category":"message","content_blocks":[]}},"artifacts":{"message":"Sure, here are some examples of the Self-Consistency Prompt technique from the document:\n\n1. **Text Generation:**\n\n   - Task: Generate a product review\n\n   - Instructions: The review should be consistent with the product information provided in the input\n\n   - Prompt formula: \"Generate a product review that is consistent with the following product information [insert product information]\"\n\n2. **Text Summarization:**\n\n   - Task: Summarize a news article\n\n   - Instructions: The summary should be consistent with the information provided in the article\n\n   - Prompt formula: \"Summarize the following news article in a way that is consistent with the information provided [insert news article]\"\n\n3. **Text Completion:**\n\n   - Task: Complete a sentence\n\n   - Instructions: The completion should be consistent with the context provided in the input\n\n   - Prompt formula: \"Complete the following sentence in a way that is consistent with the context provided [insert sentence]\"\n\n4. **Fact-checking:**\n\n   - Task: Check for consistency in a given news article\n\n   - Input text: \"The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n\n   - Prompt formula: \"Please ensure the following text is self-consistent: The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n\n5. **Data validation:**\n\n   - Task: Check for consistency in a given data set\n\n   - Input text: \"The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n\n   - Prompt formula: \"Please ensure the following text is self-consistent: The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n\nIn each of these examples, the Self-Consistency Prompt technique is used to ensure that the output generated by the model is consistent with the input provided. This helps to maintain accuracy and relevance in the generated text.","sender":"Machine","sender_name":"AI","files":[],"type":"object"},"outputs":{"message":{"message":{"timestamp":"2025-02-22T08:22:24","sender":"Machine","sender_name":"AI","session_id":"a8e187bd-44e7-4984-9218-42f63946760b","text":"Sure, here are some examples of the Self-Consistency Prompt technique from the document:\n\n1. **Text Generation:**\n   - Task: Generate a product review\n   - Instructions: The review should be consistent with the product information provided in the input\n   - Prompt formula: \"Generate a product review that is consistent with the following product information [insert product information]\"\n\n2. **Text Summarization:**\n   - Task: Summarize a news article\n   - Instructions: The summary should be consistent with the information provided in the article\n   - Prompt formula: \"Summarize the following news article in a way that is consistent with the information provided [insert news article]\"\n\n3. **Text Completion:**\n   - Task: Complete a sentence\n   - Instructions: The completion should be consistent with the context provided in the input\n   - Prompt formula: \"Complete the following sentence in a way that is consistent with the context provided [insert sentence]\"\n\n4. **Fact-checking:**\n   - Task: Check for consistency in a given news article\n   - Input text: \"The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n   - Prompt formula: \"Please ensure the following text is self-consistent: The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n\n5. **Data validation:**\n   - Task: Check for consistency in a given data set\n   - Input text: \"The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n   - Prompt formula: \"Please ensure the following text is self-consistent: The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n\nIn each of these examples, the Self-Consistency Prompt technique is used to ensure that the output generated by the model is consistent with the input provided. This helps to maintain accuracy and relevance in the generated text.","files":[],"error":false,"edit":false,"properties":{"text_color":"","background_color":"","edited":false,"source":{"id":"MistralModel-aLZcw","display_name":"MistralAI","source":"mistral-large-latest"},"icon":"MistralAI","allow_markdown":false,"positive_feedback":null,"state":"complete","targets":[]},"category":"message","content_blocks":[],"id":"876f9dd0-fa96-4ba3-81cc-43e7d2a65cec","flow_id":"a8e187bd-44e7-4984-9218-42f63946760b"},"type":"message"}},"logs":{"message":[]},"messages":[{"message":"Sure, here are some examples of the Self-Consistency Prompt technique from the document:\n\n1. **Text Generation:**\n\n   - Task: Generate a product review\n\n   - Instructions: The review should be consistent with the product information provided in the input\n\n   - Prompt formula: \"Generate a product review that is consistent with the following product information [insert product information]\"\n\n2. **Text Summarization:**\n\n   - Task: Summarize a news article\n\n   - Instructions: The summary should be consistent with the information provided in the article\n\n   - Prompt formula: \"Summarize the following news article in a way that is consistent with the information provided [insert news article]\"\n\n3. **Text Completion:**\n\n   - Task: Complete a sentence\n\n   - Instructions: The completion should be consistent with the context provided in the input\n\n   - Prompt formula: \"Complete the following sentence in a way that is consistent with the context provided [insert sentence]\"\n\n4. **Fact-checking:**\n\n   - Task: Check for consistency in a given news article\n\n   - Input text: \"The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n\n   - Prompt formula: \"Please ensure the following text is self-consistent: The article states that the population of the city is 5 million, but later on, it says that the population is 7 million.\"\n\n5. **Data validation:**\n\n   - Task: Check for consistency in a given data set\n\n   - Input text: \"The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n\n   - Prompt formula: \"Please ensure the following text is self-consistent: The data shows that the average temperature in July is 30 degrees, but the minimum temperature is recorded as 20 degrees.\"\n\nIn each of these examples, the Self-Consistency Prompt technique is used to ensure that the output generated by the model is consistent with the input provided. This helps to maintain accuracy and relevance in the generated text.","sender":"Machine","sender_name":"AI","session_id":"a8e187bd-44e7-4984-9218-42f63946760b","stream_url":null,"component_id":"ChatOutput-rzoZb","files":[],"type":"message"}],"timedelta":null,"duration":null,"component_display_name":"Chat Output","component_id":"ChatOutput-rzoZb","used_frozen_result":false}]}]}%                                                                                               charlesqin@charless-MacBook-Pro ~ % 

🔥AutoGen安装以及代码

python 复制代码
export OPENAI_API_KEY=sk-proj-xxxxxxxxxx

pip install -U "autogen-agentchat" "autogen-ext[openai]" "autogen-ext[mcp]" "mcp-server-fetch" "autogen-ext[http-tool]"

### 示例1 - 使用uvx命令调用pip安装的mcp server

import asyncio

from autogen_agentchat.agents import AssistantAgent
from autogen_ext.models.openai import OpenAIChatCompletionClient
from autogen_ext.tools.mcp import StdioServerParams, mcp_server_tools

async def main() -> None:
    # Get the fetch tool from mcp-server-fetch.
    fetch_mcp_server = StdioServerParams(command="uvx", args=["mcp-server-fetch"])
    tools = await mcp_server_tools(fetch_mcp_server)

    # Create an agent that can use the fetch tool.
    model_client = OpenAIChatCompletionClient(model="gpt-4o")
    agent = AssistantAgent(name="fetcher", model_client=model_client, tools=tools, reflect_on_tool_use=True)  # type: ignore

    # Let the agent fetch the content of a URL and summarize it.
    result = await agent.run(task="Summarize the content of <https://en.wikipedia.org/wiki/Seattle>")
    print(result.messages[-1].content)

asyncio.run(main())

### 示例2 - 使用node命令直接调用已安装mcp server

import asyncio

from autogen_agentchat.agents import AssistantAgent
from autogen_ext.models.openai import OpenAIChatCompletionClient
from autogen_ext.tools.mcp import StdioServerParams, mcp_server_tools

async def main() -> None:
    # Get the fetch tool from mcp-server-fetch.
    fetch_mcp_server = StdioServerParams(command="node", args=["/Users/charlesqin/Documents/Cline/MCP/browser-use/build/index.js"])
    tools = await mcp_server_tools(fetch_mcp_server)

    # Create an agent that can use the fetch tool.
    model_client = OpenAIChatCompletionClient(model="gpt-4o-mini")
    agent = AssistantAgent(name="fetcher", model_client=model_client, tools=tools, reflect_on_tool_use=True)  # type: ignore

    # Let the agent fetch the content of a URL and summarize it.
    result = await agent.run(task="show me some examples about Self-Consistency Prompt ")
    print(result.messages[-1].content)

asyncio.run(main())
相关推荐
猫头虎-人工智能1 小时前
NVIDIA A100 SXM4与NVIDIA A100 PCIe版本区别深度对比:架构、性能与场景解析
gpt·架构·机器人·aigc·文心一言·palm
冰 河2 小时前
‌最新版DeepSeek保姆级安装教程:本地部署+避坑指南
人工智能·程序员·openai·deepseek·冰河大模型
无奈何杨1 天前
免费使用满血版DeepSeek-R1的多种方案
openai·deepseek
极客密码1 天前
大厂出品!三个新的 DeepSeek 平替网站
aigc·cursor·deepseek
Jamence1 天前
国产开源PDF解析工具MinerU
人工智能·pdf·aigc
AIGC安琪1 天前
【Stable Diffusion】SD迎来动画革命,AnimateDiff快速出图
人工智能·网络协议·tcp/ip·stable diffusion·aigc
花千树-0101 天前
Java中的自然语言处理(NLP)工具:Stanford NLP、Apache OpenNLP、DL4J
java·自然语言处理·nlp·aigc·apache
天天向上杰2 天前
通义灵码AI程序员
人工智能·aigc·ai编程
Linux猿2 天前
OpenAI Swarm 多智能体框架介绍
openai·多智能体·swarm·智能体·openai swarm·多智能体框架