微信扫码
添加专属顾问
我要投稿
MCP协议如何让大语言模型更智能?揭秘AI调用外部工具的最佳实践。 核心内容: 1. MCP协议解决LLM调用外部工具的核心痛点 2. 协议架构设计与标准化交互流程解析 3. 实际应用场景与未来发展方向
那些LLM不知道的事
开篇先尝试直接问LLM一个问题,“今天天气如何”。
然而,并未能从LLM获得期望回答。原因也很简单,今天是哪天?天气是哪里的天气?这些问题对于LLM来说统统不得而知。
因此,我们很自然地想到,是不是能让LLM自己学会用工具,哪里不会点哪里呢?
当LLM学会用工具
“让LLM自己学会用工具,来解答用户问题。”
上面这句话中,出现了三个角色,“用户”、“工具”、“LLM”,以及隐藏的第四个角色——将这一切粘合起来的“主控程序”。
关于四者的交互流程,我从百炼找了张图,供以参考:
MCP干嘛来了
没有MCP,我要怎么做
按着Agent+FunctionCall的模式,我设计了工具schema,走通了LLM的服务调用,终于让LLM学会了用工具。但随着工具越来越多、工具调用与LLM耦合得越来越深,不管是维护还是迭代,都会消耗大量的精力。
那么,问题来了:
- 有了MCP,我会怎么做
现在有了MCP,一切都好起来了:
近距离看看MCP
MCP is an open protocol that standardizes how applications provide context to LLMs. Think of MCP like a USB-C port for AI applications. Just as USB-C provides a standardized way to connect your devices to various peripherals and accessories, MCP provides a standardized way to connect AI models to different data sources and tools.
MCP架构中的角色主要有以下几种:
ps:写了个mcp demo,就想让LLM告诉我,今天天气到底如何?
mcp = FastMCP("Demo")
name="get_current_time",
description="获取当前时间",
)
def get_current_time():
"""
获取当前时间并进行格式化展示
:return:
"""
now = datetime.datetime.now()
formatted_time = now.strftime("%Y-%m-%d %H:%M:%S")
return formatted_time
name="get_location",
description="获取当前地点",
)
def get_location():
"""
获取当前地点
:return:
"""
try:
response = requests.get("http://ip-api.com/json/")
data = response.json()
if data["status"] == "success":
location_info = {
"country": data.get("country", ""),
"region": data.get("regionName", ""),
"city": data.get("city", "")
}
return json.dumps(location_info, ensure_ascii=False)
else:
return json.dumps({"error": "无法获取地理位置"}, ensure_ascii=False)
except Exception as e:
return json.dumps({"error": str(e)}, ensure_ascii=False)
AI搜索怎么玩MCP
场景一:文件解析与总结
API Provider选择 OpenAI Compatible
Base URL设为:
https://dashscope.aliyuncs.com/compatible-mode/v1
curl -LsSf https://astral.sh/uv/install.sh | sh 或者 pip install uv
{ "mcpServers": { "aisearch-mcp-server": { "command": "uv", "args": [ "--directory", "/path/to/aisearch-mcp-server", "run", "aisearch-mcp-server" ], "env": { "AISEARCH_API_KEY": "<AISEARCH_API_KEY>", "AISEARCH_ENDPOINT": "<AISEARCH_ENDPOINT>" } } }}
此处为语雀视频卡片,点击链接查看:aisearch_mcp_demo.mp4
场景二:向量检索及排序
(新增)开通 opensearch向量检索版[4],构建一张向量表
(其他)同场景一
{ "mcpServers": { "aisearch-mcp-server": { "command": "uv", "args": [ "--directory", "/path/to/aisearch-mcp-server", "run", "aisearch-mcp-server" ], "env": { "AISEARCH_API_KEY": "<AISEARCH_API_KEY>", "AISEARCH_ENDPOINT": "<AISEARCH_ENDPOINT>" } }, "opensearch-vector-mcp-server": { "command": "uv", "args": [ "--directory", "/path/to/opensearch-vector-mcp-server", "run", "opensearch-vector-mcp-server" ], "env": { "OPENSEARCH_VECTOR_ENDPOINT": "http://ha-cn-***.public.ha.aliyuncs.com", "OPENSEARCH_VECTOR_USERNAME": "<username>", "OPENSEARCH_VECTOR_PASSWORD": "<password>", "OPENSEARCH_VECTOR_INSTANCE_ID": "ha-cn-***", "OPENSEARCH_VECTOR_INDEX_NAME": "<Optional: index in vector table>", "AISEARCH_API_KEY": "<Optional: AISEARCH_API_KEY for embedding>", "AISEARCH_ENDPOINT": "<Optional: AISEARCH_ENDPOINT for embedding>" } } }}
4. 业务价值
场景三:Elasticsearch智能检索
(新增)开通 Elasticsearch[5],创建一份索引并写入测试数据
(其他)同场景一
{ "mcpServers": { "elasticsearch-mcp-server": { "command": "npx", "args": [ "-y", "@elastic/mcp-server-elasticsearch" ], "env": { "ES_URL": "http://es-cn-***.public.elasticsearch.aliyuncs.com:9200", "ES_USERNAME": "<USERNAME>", "ES_PASSWORD": "<PASSWORD>" } } }}
53AI,企业落地大模型首选服务商
产品:场景落地咨询+大模型应用平台+行业解决方案
承诺:免费POC验证,效果达标后再合作。零风险落地应用大模型,已交付160+中大型企业
2025-08-15
如何让 AI 绘图中文呈现更稳定和准确?
2025-08-15
含全文!OpenAI发布GPT-5官方Prompt指南
2025-08-15
道理都懂,做到很难!有赞白鸦的分享与AI赋能的启发
2025-08-15
MNN LLM Chat iOS 流式输出优化实践
2025-08-15
优tech分享 | 入局AI Infra:程序员必须了解的AI系统设计与挑战知识
2025-08-15
Kimi-K2模型真实项目OOP重构实践
2025-08-15
腾讯云上新CloudBase AI CLI,可减少80%编码量
2025-08-15
Altair重磅发布:100个AI赋能的工程应用案例,揭示“万物皆可解”的未来
2025-05-29
2025-05-23
2025-06-01
2025-06-21
2025-06-07
2025-05-20
2025-06-12
2025-06-19
2025-06-13
2025-05-28