MCP(Model Context Protocol)与提示词撰写

随着大模型(LLM)在复杂任务中的普及,如何让模型高效调用外部工具和数据成为关键挑战。传统函数调用(Function Calling)依赖开发者手动封装 API,而 MCP(Model Context Protocol) 通过标准化协议,实现了模型与工具的无缝对接,成为新一代 Agent 开发的核心基础设施。

简言之,MCP 是 AI 的“万能接口”,类似 USB-C 的通用性,让开发者无需重复造轮子即可连接数据库、本地文件、第三方服务等资源。


一、MCP 的核心原理:从函数调用到协议层革新

1. 传统函数调用的局限性
  • 工作流程复杂:需预定义函数、解析自然语言指令、手动处理参数与返回结果。
  • 维护成本高:每新增一个工具需重新编码适配,难以动态扩展。
  • 示例:调用股票查询工具需逐步解析用户指令 → 匹配函数 → 传参 → 返回结果。
2. MCP 的突破性设计
  • 协议层标准化:工具功能通过 MCP Server 暴露,模型通过统一协议调用,无需感知底层实现。
  • 自解释性:工具的描述、参数格式、返回值结构均以标准化 JSON Schema 定义,模型可零样本理解。
  • 动态发现:客户端(如 ChatGPT)可自动加载已注册的 MCP 工具列表,用户即选即用。

MCP vs. 传统 API 集成对比

维度传统函数调用MCP 协议
工具接入成本高(需代码适配)低(声明式描述)
动态扩展性强(服务热注册)
跨模型兼容性依赖模型适配协议统一,通用性强
典型应用场景简单工具调用复杂 Agent 工作流

二、MCP 提示词撰写的核心技巧

MCP 的效能高度依赖提示词设计。以下是关键实践原则:

1. 结构化提示词模板(MCP Prompts)
  • 定义清晰组件
    {"name": "股票查询工具","description": "获取指定股票代码的实时价格","arguments": [{ "name": "ticker", "description": "股票代码", "required": true }]
    }
    
    通过标准化字段声明工具功能,模型可自动生成调用逻辑。
  • 动态参数注入:支持从上下文(如用户输入、前置工具输出)自动填充参数。
2. 上下文优化四要素
  • 目标清晰化:明确任务目标(如“生成三条徒步路线”而非“推荐路线”)。
  • 格式约束:指定输出结构(如表格、Markdown),提升结果可读性。
  • 错误规避:添加验证逻辑(如“仅返回 AllTrails 可验证的路线”)。
  • 背景信息:注入用户偏好(如“避免热门路线”“沿海步道优先”)。
3. 安全边界设计
  • 风险提示:在工具描述中声明潜在风险(如“此操作将删除文件”)。
  • 权限分级:敏感工具(如数据库写入)需显式用户授权。

三、MCP 提示词实战案例:徒步路线生成工具

场景需求

用户输入:“推荐旧金山周边 3 条中等难度徒步路线,车程<2小时,偏好冷门路线。”

优化后的 MCP 提示词设计
{"name": "hiking_route_recommend","description": "基于位置和偏好生成徒步路线","arguments": [{ "name": "location", "description": "中心位置(如城市名)" },{ "name": "max_drive_time", "description": "最大车程(分钟)" },{ "name": "difficulty", "description": "难度等级(easy/medium/hard)" },{ "name": "preference_tags", "description": "偏好标签(如 coastal, historic)" }],"output_format": "表格(路线名称、起点、距离、特色)","constraints": ["路线需在 AllTrails 可验证","避开用户近期已访问路线(见上下文)"]
}

效果对比

  • 传统调用:模型可能返回模糊描述(“尝试 Mission Peak 步道”)。
  • MCP 调用:返回结构化表格,含可验证路线详情。

四、MCP 的局限性与应对策略

1. 当前挑战
  • 安全风险:恶意提示词注入可能操控工具行为(如篡改数据库)。
  • 性能瓶颈:复杂工具链可能导致响应延迟。
  • 工具生态碎片化:不同 MCP Server 实现质量参差。
2. 最佳实践建议
  • 工具分级:区分“查询类”与“执行类”工具,后者强制人工审核。
  • 测试沙盒:使用 mcp-chat 等工具模拟调用流程。
  • 生态整合:优先选择 smithery.aiMCP Market 等认证工具库。

五、未来展望:MCP 与提示词工程的融合演进

  1. 自然语言工具生成:模型根据用户描述自动创建 MCP 工具模板。
  2. 安全协议强化:预计 2025 年推出 MCP 安全扩展标准(如 OAuth 集成)。
  3. 操作系统级支持:苹果、微软等巨头正探索系统原生 MCP 框架,降低用户使用门槛。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/pingmian/84029.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RootSIFT的目标定位,opencvsharp。

首先截取匹配模板&#xff0c;然后使用rootsift特征匹配&#xff0c;最后定位目标。 对于微弱变化&#xff0c;还是能够识别定位的&#xff0c;对于传统算法来说已经不错了。 目标定位效果&#xff1a; 使用的模板图片。 using OpenCvSharp; using OpenCvSharp.Features2D;u…

Appium如何支持ios真机测试

ios模拟器上UI自动化测试 以appiumwebdriverio为例&#xff0c;详细介绍如何在模拟器上安装和测试app。在使用ios模拟器前&#xff0c;需要安装xcode&#xff0c;创建和启动一个simulator。simulator创建好后&#xff0c;就可以使用xcrun simctl命令安装被测应用并开始测试了。…

近几年字节飞书测开部分面试题整理

文章目录 一、面试问题1. 创建索引2. 拦截器&#xff08;Interceptor&#xff09;和过滤器&#xff08;Filter&#xff09;的区别3. 为什么jwt令牌代替session&#xff1f;4. 有一个100行的数据&#xff0c;和一个1万行的数据&#xff0c;写sql 的时候要注意什么&#xff1f;5.…

JDBC基础关键_001_认识

目 录 一、概述 二、原理 三、接口的作用 四、JDBC 模拟 1.JDBC 接口 2.驱动 3.配置文件 4.调用者 一、概述 JDBC&#xff08;Java DataBase Connectivity&#xff09;&#xff0c;Java 数据库连接&#xff1b;是用 Java 语言操作数据库&#xff0c;使用 Java 语言向数…

SWAN(Scade One) 语言原理介绍

SCADE 团队于2024年推出了下一代 SCADE 工具 Scade One&#xff0c;工具的建模语言也基于Scade 6 进行了演化。在语言命名方面&#xff0c;并没有复用"Scade"这一标志性的名称&#xff0c;而是使用了新的名字&#xff1a;Swan。在本篇中&#xff0c;将叙述 Swan 语言…

【工具教程】多个条形码识别用条码内容对图片重命名,批量PDF条形码识别后用条码内容批量改名,使用教程及注意事项

一、条形码识别改名使用教程 打开软件并选择处理模式&#xff1a;打开软件后&#xff0c;根据要处理的文件类型&#xff0c;选择 “图片识别模式” 或 “PDF 识别模式”。如果是处理包含条形码的 PDF 文件&#xff0c;就选择 “PDF 识别模式”&#xff1b;若是处理图片文件&…

sql中group by使用场景

GROUP BY语句在SQL中用于将多个记录分组为较小的记录集合&#xff0c;以便对每个组执行聚合函数&#xff0c;如COUNT(), MAX(), MIN(), SUM(), AVG()等。GROUP BY的使用场景非常广泛&#xff0c;以下是一些典型的应用场景&#xff1a; 统计数量 当你想要计算某个字段的唯一值数…

MongoDB慢查询临时开启方法讲解

1、首先连接数据库 mongosh "mongodb://localhost:27017" 2、选择目标数据库 show databases;#显示所有数据库 use lidb;#使用某数据库 3、查看当前分析级别 db.getProfilingStatus() 输出 { was: 0, slowms: 100, sampleRate: 1, ok: 1 } #was0表示关闭&…

UML活动图与泳道图

活动图的作用&#xff0c;与用例图类似&#xff0c;也是帮助我们捕获用户的需求。 活动图主要是用来描述用户的业务流程&#xff0c;如果能把用户的这个业务流程描述的很清楚的话&#xff0c;就可以帮助我们做用例分析。 1 活动图定义 活动图描述了在一个过程中&#xff0c;…

算法练习-回溯

今天给大家带来的是在dfs查用的降低复杂度的方法---剪枝 所谓减枝 第一题 代码部分&#xff1a;&#xff08;未剪枝&#xff09; 代码部分&#xff08;剪枝&#xff09; 第二题 代码部分&#xff08;未剪枝&#xff09; 剪枝后 通过这些题目可以看出如果没有进行剪枝操作&#…

Elasticsearch + Milvus 构建高效知识库问答系统《一》

&#x1f50d; Elasticsearch Milvus 构建高效知识库问答系统&#xff08;RAG 技术实战&#xff09; &#x1f4cc; 目录 背景介绍Elasticsearch 在知识库检索中的作用Milvus 在知识库检索中的作用混合检索&#xff1a;Elasticsearch Milvus完整代码实现部署建议与优化方向…

10万QPS高并发请求,如何防止重复下单

1. 前端拦截 首先因为是10万QPS的高并发请求&#xff0c;我们要保护好系统&#xff0c;那就是尽可能减少用户无效请求。 1.1 按钮置灰 很多用户抢票、抢购、抢红包等时候&#xff0c;为了提高抢中的概率&#xff0c;都是疯狂点击按钮。会触发多次请求&#xff0c;导致重复下…

基于单片机的病房呼叫系统(源码+仿真)

该系统由以 STM32F4 为平台的监控终端以及以 CC2530 为平台的无线传感网组成。系统上电后自动完成 ZigBee 网络的组建、终端节点的加入&#xff0c;病人可利用便携式的病人终端发出呼叫求助请求信息、节点在线信息以及对护士的服务评价信息等&#xff0c;这些信息通过路由节点发…

使用WebSocket实时获取印度股票数据源(无调用次数限制)实战

使用WebSocket实时获取印度股票数据源&#xff08;无调用次数限制&#xff09;实战 一、前置准备 1. 获取API密钥 登录 StockTV开发者平台 → 联系客服获取测试Key&#xff08;格式MY4b781f618e3f43c4b055f25fa61941ad&#xff09;&#xff0c;该密钥无调用次数限制且支持实时…

kafka消息积压排查

kafka监控搭建&#xff1a;https://insights.blog.csdn.net/article/details/139129552?spm1001.2101.3001.6650.1&utm_mediumdistribute.pc_relevant.none-task-blog-2%7Edefault%7Ebaidujs_baidulandingword%7EPaidSort-1-139129552-blog-132216491.235%5Ev43%5Econtrol…

Matlab回归预测大合集又更新啦!新增2种高斯过程回归预测模型,已更新41个模型!性价比拉满!

Matlab回归预测大合集又更新啦&#xff01;新增2种高斯过程回归预测模型&#xff0c;已更新41个模型&#xff01;性价比拉满&#xff01; 目录 Matlab回归预测大合集又更新啦&#xff01;新增2种高斯过程回归预测模型&#xff0c;已更新41个模型&#xff01;性价比拉满&#xf…

6套bootstrap后台管理界面源码

后端管理系统是指一种用于管理和监控网站、应用程序或系统的后台管理界面。它通常由一组后端代码和数据库组成&#xff0c;用于处理和存储数据&#xff0c;提供给前端用户界面展示和操作数据。 后端管理系统的功能和特点可以包括&#xff1a; 用户权限管理&#xff1a;可以设…

JavaScript性能优化实战:从核心原理到工程实践的全流程解析

下面我给出一个较为系统和深入的解析&#xff0c;帮助你理解和实践“JavaScript 性能优化实战&#xff1a;从核心原理到工程实践的全流程解析”。下面的内容不仅解释了底层原理&#xff0c;也结合实际工程中的最佳模式和工具&#xff0c;帮助你在项目中贯彻性能优化理念&#x…

ELK日志管理框架介绍

在小铃铛的毕业设计中涉及到了ELK日志管理框架&#xff0c;在调研期间发现在中文中没有很好的对ELK框架进行介绍的文章&#xff0c;因此拟在本文中进行较为详细的实现的介绍。 理论知识 ELK 框架介绍 ELK 是一个流行的开源日志管理解决方案堆栈&#xff0c;由三个核心组件组…

2025.6.4总结

工作&#xff1a;今天效率比较高&#xff0c;早上回归4个问题&#xff0c;下午找了3个bug&#xff0c;晚上二刷了科目一&#xff08;贪吃蛇系统&#xff09;&#xff0c;写了四个点&#xff0c;唯一没达标的就是两自动化没完成。美中不足的是电脑上下载不了PC版的番茄工作软件。…