微信扫码
添加专属顾问
我要投稿
探索AI连接新篇章,MCP协议如何成为AI领域的“USB-C”? 核心内容: 1. MCP协议的革命性意义及其与USB-C的类比 2. MCP的核心组件及其工作原理 3. MCP如何实现AI应用与外部资源的无缝连接
哪MCP具体是什么?
MCP,全称Model Context Protocol(模型上下文协议),是一种开放标准,旨在标准化AI应用与各种数据源和工具之间的连接。正如USB-C接口为设备与配件提供了一种通用的连接方式,MCP为AI应用提供了一种类似的标准接口,让AI模型能够轻松访问数据库、Web API、本地文件系统、GitHub、Gmail等外部资源。
MCP Host(主机):AI应用本身,如Claude Desktop或AI驱动的IDE,提供AI交互环境,并运行MCP Client。
MCP Client(客户端):运行在主机中,负责与MCP服务器通信,启用AI应用与外部数据源的连接。
MCP Server(服务器):暴露特定功能和数据访问权限,包括:
工具(Tools):使大型语言模型(LLMs)能够通过服务器执行操作。
资源(Resources):向LLMs提供服务器中的数据和内容。
提示(Prompts):创建可重用的提示模板和工作流。
下面拆分来讲这三部分如何工作、协作以及通信:
1. MCP Host(主机):AI应用的“指挥中心”
MCP Host是指运行AI应用的平台或环境,例如Claude Desktop、Cursor(一款AI驱动的IDE)或其他AI工具。这些主机为用户提供了一个交互环境,允许AI模型与用户进行对话、执行任务或处理复杂问题。MCP Host的主要功能包括:
提供AI交互环境:无论是聊天助手、代码编辑器还是其他AI驱动的工具,MCP Host都是AI功能的承载平台。
访问工具和数据:通过运行MCP Client,主机能够连接到外部数据源(如数据库、Web API)和工具(如GitHub、Gmail),从而获取必要的信息或执行操作。
运行MCP Client:MCP Host内嵌MCP Client,作为与外部MCP服务器通信的桥梁,确保AI应用能够动态访问和利用外部资源。
例如,在Claude Desktop中,用户可以通过MCP Host发起查询或任务请求,主机随后通过MCP Client与服务器交互,获取相关数据或工具支持。
MCP服务器具备三大关键功能,具体如下:
1. 工具(Tools)
MCP服务器可以提供功能性工具,允许大型语言模型(LLMs)在用户批准后执行具体操作。例如,一个天气API的MCP服务器可以提供工具来调用天气查询API端点,执行实时天气预报任务。这些工具让AI应用能够主动与外部系统交互,而不仅仅是被动接收数据。
2. 资源(Resources)
服务器可以向AI客户端暴露文件式数据或内容,如API响应、文件内容或数据库记录。这些资源为AI模型提供了丰富的上下文信息,帮助它理解用户需求并生成更精准的回答。例如,连接到GitHub的MCP服务器可以提供代码仓库的资源,供AI工具分析代码或提供补全建议。
3. 提示(Prompts)
MCP服务器支持创建可重用的提示模板和工作流,帮助用户快速完成特定任务。例如,一个MCP服务器可以提供预定义的提示模板,用于生成电子邮件草稿或优化代码注释。这些提示增强了AI应用的灵活性和用户体验。
3. MCP Client(客户端):连接的“使者”
MCP Client是运行在MCP Host内部的组件,负责实现主机与MCP服务器之间的通信。它的核心作用包括:
启用与服务器的通信:MCP Client通过“Transport Layers”(传输层)与MCP服务器建立连接,发送请求并接收响应。
动态发现资源:客户端能够自动识别和利用服务器提供的工具、资源和提示(Prompts),从而让AI应用更高效地完成任务。
保持权限控制:MCP Client确保主机对AI模型访问和数据权限的控制,保障安全性和隐私性。
简单来说,MCP Client就像是AI应用与外部世界的“使者”,它负责将主机的需求传递给服务器,并将服务器的响应反馈给主机。这种设计使得AI应用无需直接与每个数据源或工具建立单独的连接,而是通过统一的MCP协议实现灵活、高效的集成。
MCP为何重要?
MCP作为一个开放标准,它解决了AI应用与外部数据源连接的碎片化问题。传统上,AI系统需要为每个数据源(如数据库、API、文件系统)开发特定的集成接口,过程复杂且难以维护。而MCP通过客户端-服务器架构,提供了一个通用的解决方案,使AI应用能够轻松连接到多样化的外部资源。
接下面,我们动手来实现一个AI SQL 代理!让你可以与 SQLite 数据库进行聊天!代码示例来自:https://shorturl.at/4ilMV
import sqlite3from loguru import loggerfrom mcp.server.fastmcp import FastMCPmcp = FastMCP("SQL Agent Server").tool()def query_data(sql: str) -> str: """Execute SQL queries safely.""" logger.info(f"Executing SQL query: {sql}") conn = sqlite3.connect("./database.db") try: result = conn.execute(sql).fetchall() conn.commit() return "\n".join(str(row) for row in result) except Exception as e: return f"Error: {str(e)}" finally: conn.close()if __name__ == "__main__": print("Starting server...") mcp.run(transport="stdio")
2. 构建客户端(mcp_client.py):
接下来,构建客户端,使用 Anthropic 的 Claude 3 Sonnet 将自然语言转换为 SQL。
import asynciofrom dataclasses import dataclass, fieldfrom typing import Union, castimport anthropicfrom anthropic.types import MessageParam, TextBlock, ToolUnionParam, ToolUseBlockfrom dotenv import load_dotenvfrom mcp import ClientSession, StdioServerParametersfrom mcp.client.stdio import stdio_clientload_dotenv()anthropic_client = anthropic.AsyncAnthropic()server_params = StdioServerParameters(command="python", args=["./mcp_server.py"], env=None)class Chat: messages: list[MessageParam] = field(default_factory=list) system_prompt: str = """You are a master SQLite assistant. Your job is to use the tools at your disposal to execute SQL queries and provide the results to the user.""" async def process_query(self, session: ClientSession, query: str) -> None: response = await session.list_tools() available_tools: list[ToolUnionParam] = [ {"name": tool.name, "description": tool.description or "", "input_schema": tool.inputSchema} for tool in response.tools ] res = await anthropic_client.messages.create(model="claude-3-7-sonnet-latest", system=self.system_prompt, max_tokens=8000, messages=self.messages, tools=available_tools) assistant_message_content: list[Union[ToolUseBlock, TextBlock]] = [] for content in res.content: if content.type == "text": assistant_message_content.append(content) print(content.text) elif content.type == "tool_use": tool_name = content.name tool_args = content.input result = await session.call_tool(tool_name, cast(dict, tool_args)) assistant_message_content.append(content) self.messages.append({"role": "assistant", "content": assistant_message_content}) self.messages.append({"role": "user", "content": [{"type": "tool_result", "tool_use_id": content.id, "content": getattr(result.content[0], "text", "")}]}) res = await anthropic_client.messages.create(model="claude-3-7-sonnet-latest", max_tokens=8000, messages=self.messages, tools=available_tools) self.messages.append({"role": "assistant", "content": getattr(res.content[0], "text", "")}) print(getattr(res.content[0], "text", "")) async def chat_loop(self, session: ClientSession): while True: query = input("\nQuery: ").strip() self.messages.append(MessageParam(role="user", content=query)) await self.process_query(session, query) async def run(self): async with stdio_client(server_params) as (read, write): async with ClientSession(read, write) as session: await session.initialize() await self.chat_loop(session)chat = Chat()asyncio.run(chat.run())
该客户端连接到服务器,将用户输入发送给 Claude,然后使用 MCP 运行 SQL 查询。
程序虽然比较简单,但我们从头通过MCP完成了Claude 3 Sonnet生成 SQL 查询!
53AI,企业落地大模型首选服务商
产品:场景落地咨询+大模型应用平台+行业解决方案
承诺:免费场景POC验证,效果验证后签署服务协议。零风险落地应用大模型,已交付160+中大型企业
2025-03-20
Claude Code 系统提示词和 11个内置 Tool拆解
2025-03-20
大模型的数学推理能力为何难解初一题?
2025-03-20
关于 DeepSeek-R1 API 评测,至少有 7 个误区
2025-03-20
聊聊大模型MCP模型上下文协议-为何是AI在企业内应用落地的一个关键组件
2025-03-20
MCP核心架构解析,赋能AI智能体(上)
2025-03-20
技术详解丨深度分析MCP工作原理,附代码实现(下)
2025-03-20
Manus的技术实现原理浅析与简单复刻
2025-03-20
Manus 是大模型 AI Agent + MCP, 那什么是模型上下文协议 (MCP)?
2024-08-13
2024-06-13
2024-09-23
2024-08-21
2024-07-31
2024-05-28
2024-08-04
2024-04-26
2024-07-09
2024-09-17
2025-03-20
2025-03-20
2025-03-20
2025-03-19
2025-03-19
2025-03-18
2025-03-18
2025-03-18