当前位置: 首页 > article >正文

FastMCP 装饰器源码探秘:从 tool() 到 prompt() 的注册与转换机制

1. FastMCP装饰器机制概览FastMCP作为MCP协议的Python实现其核心魔力在于三个装饰器tool()、resource()和prompt()。这些装饰器就像魔法棒能将普通Python函数变成MCP生态系统中的标准组件。想象你正在搭建一个天气查询服务只需要几行代码from mcp.server.fastmcp import FastMCP mcp FastMCP(nameweather) mcp.tool() def get_weather(city: str) - str: 获取指定城市的天气信息 return f{city}的天气是晴朗这个简单的tool()背后其实完成了函数签名解析、参数Schema生成、类型转换等复杂操作。装饰器的工作原理就像流水线函数包装捕获被装饰函数的元信息签名解析提取参数类型和返回类型Schema生成创建符合MCP规范的接口描述注册管理将组件添加到对应的管理器2. 装饰器核心实现解析2.1 装饰器工厂模式FastMCP采用装饰器工厂模式这是Python中实现可配置装饰器的经典方式。以tool()为例def tool(self, nameNone, titleNone, descriptionNone) - Callable: # 检查装饰器是否被正确调用 if callable(name): raise TypeError(需使用tool()而非tool) def decorator(fn: Callable) - Callable: self.add_tool(fn, namename, titletitle, descriptiondescription) return fn return decorator这种结构允许装饰器接收配置参数同时保持被装饰函数的原始签名。当看到mcp.tool(nameweather_tool)时先执行tool(nameweather_tool)返回decorator函数再用decorator装饰目标函数2.2 类型系统集成FastMCP深度集成Python类型注解系统通过inspect模块实现智能解析import inspect def process_function(fn): sig inspect.signature(fn) params sig.parameters for name, param in params.items(): print(f参数 {name}: 类型{param.annotation} 默认值{param.default})对于这个天气查询函数mcp.tool() def get_weather(city: str 北京) - str: ...装饰器会提取参数city类型为str默认值北京返回类型为str3. 组件注册全流程3.1 Tool注册机制tool()的完整注册流程包含这些关键步骤元数据提取func_name name or fn.__name__ func_doc description or fn.__doc__ or is_async inspect.iscoroutinefunction(fn)参数模型构建from pydantic import create_model ArgModel create_model( f{func_name}Arguments, __base__BaseModel, **dynamic_fields )工具实例化tool Tool( namefunc_name, descriptionfunc_doc, parametersArgModel.schema(), fnfn )注册到管理器self._tool_manager.add_tool(tool)3.2 类型转换黑科技FastMCP会自动处理类型转换例如将字符串转为Message对象mcp.prompt() def weather_prompt(city: str) - list: # 返回简单字符串也会被自动包装 return f查询{city}天气背后的转换逻辑if isinstance(result, str): return [UserMessage(contentTextContent(textresult))]4. 三大装饰器对比特性tool()resource()prompt()核心用途功能工具数据资源对话模板必需参数无URI字符串无返回类型任意str/bytes/dictList[Message]异步支持是是是管理器ToolManagerResourceManagerPromptManager5. 实战中的坑与技巧5.1 常见问题排查当装饰器不工作时可以这样调试检查函数签名print(inspect.signature(your_function))验证类型注解from typing import get_type_hints print(get_type_hints(your_function))查看生成的Schematool mcp._tool_manager._tools[your_tool] print(tool.parameters)5.2 性能优化建议对于高频调用的工具函数使用functools.lru_cache缓存结果from functools import lru_cache mcp.tool() lru_cache(maxsize100) def cached_query(param: str) - str: ...避免在装饰器参数中做复杂计算# 不推荐 mcp.tool(descriptiongenerate_complex_desc()) # 推荐 DESC generate_complex_desc() mcp.tool(descriptionDESC)6. 深入源码关键类6.1 ToolManager解析ToolManager是工具组件的核心管家主要数据结构class ToolManager: def __init__(self): self._tools: dict[str, Tool] {} self._lock threading.Lock() def add_tool(self, tool: Tool): with self._lock: if tool.name in self._tools: raise ValueError(f工具{tool.name}已存在) self._tools[tool.name] tool关键方法get_tool(name)按名称获取工具list_tools()返回所有工具remove_tool(name)移除指定工具6.2 类型适配系统TypeAdapter负责处理各种参数类型from pydantic import TypeAdapter adapter TypeAdapter(Union[str, int, float]) def validate_input(value): try: return adapter.validate_python(value) except ValidationError as e: print(f类型错误: {e})这套系统支持基础类型str/int/float等复合类型List/Dict/Union等自定义Pydantic模型7. 自定义装饰器进阶7.1 扩展装饰器功能继承FastMCP创建自定义装饰器class CustomMCP(FastMCP): def custom_decorator(self, **kwargs): def decorator(fn): # 前置处理 print(f注册函数: {fn.__name__}) # 调用原始装饰器 tool self.tool(**kwargs)(fn) # 后置处理 self._custom_registry[fn.__name__] fn return tool return decorator7.2 动态参数处理处理带可变参数的函数mcp.tool() def dynamic_args(**kwargs): 接收任意关键字参数 return kwargs # 自动生成的Schema会包含额外属性字段 additional_properties { additionalProperties: True }8. 调试与问题诊断8.1 使用调试工具FastMCP提供了内置调试工具元数据检查器python -m mcp.inspect your_server.py实时日志监控mcp FastMCP(debugTrue) # 启用详细日志8.2 常见错误处理签名解析失败 检查函数是否使用了不支持的参数类型如*args类型转换错误 确保返回类型与声明一致必要时添加显式转换命名冲突 使用name参数显式指定唯一标识符mcp.tool(nameunique_weather) def get_weather(): ...通过源码分析我们发现FastMCP的装饰器设计完美体现了Python的约定优于配置哲学。在实际项目中合理利用这些装饰器可以大幅提升开发效率但也要注意类型系统的严格校验可能带来的学习曲线。

相关文章:

FastMCP 装饰器源码探秘:从 tool() 到 prompt() 的注册与转换机制

1. FastMCP装饰器机制概览 FastMCP作为MCP协议的Python实现,其核心魔力在于三个装饰器:tool()、resource()和prompt()。这些装饰器就像魔法棒,能将普通Python函数变成MCP生态系统中的标准组件。想象你正在搭建一个天气查询服务,只…...

Ostrakon-VL-8B嵌入式部署初探:轻量级模型在边缘计算设备上的应用

Ostrakon-VL-8B嵌入式部署初探:轻量级模型在边缘计算设备上的应用 1. 引言 最近几年,大模型在云端服务器上大放异彩,但一提到把它们塞进摄像头、工控机或者智能家居设备里,很多人第一反应就是“不可能”。动辄几十上百亿参数的模…...

Sentaurus TCAD Sprocess仿真坐标系详解:从晶圆坐标到离子注入,新手避坑指南

Sentaurus TCAD Sprocess仿真坐标系实战解析:从晶圆定位到离子注入精准控制 1. 初识Sentaurus TCAD坐标系:为什么新手总在第一步栽跟头? 刚接触Sentaurus TCAD的工程师常会遇到这样的场景:明明按照手册设置了离子注入角度&#xf…...

2025.04.15【技术前沿】| scran:解锁单细胞RNA测序数据潜能的瑞士军刀

1. scran:单细胞数据分析的瑞士军刀 第一次接触单细胞RNA测序数据时,我被海量的基因表达矩阵弄得晕头转向。直到实验室的师兄推荐了scran,这个R包彻底改变了我的分析体验。就像瑞士军刀一样,scran把二十多种常用工具集成在一个包里…...

中文文本查重不求人:StructBERT相似度计算WebUI快速上手指南

中文文本查重不求人:StructBERT相似度计算WebUI快速上手指南 你是不是经常遇到这样的烦恼?面对一堆用户评论,不知道哪些是重复的;客服系统里,用户问的问题千奇百怪,但知识库里的标准答案就那么几个&#x…...

编程实战:苹果与虫子的数学博弈——从基础条件判断到算法优化

1. 从生活场景理解苹果与虫子问题 想象你有一筐新鲜的红苹果,放在院子里忘记盖盖子。过了一晚上,你发现有几只虫子正在啃食这些苹果。这时候你可能会想:经过这一夜的啃食,筐里还能剩下多少完整的苹果呢?这就是经典的&q…...

Vue3企业级后台管理系统架构深度解析:vue-admin-box实战剖析

Vue3企业级后台管理系统架构深度解析:vue-admin-box实战剖析 【免费下载链接】vue-admin-box vue3,vite,element-plus中后台管理系统,集成四套基础模板,大量可利用组件,模板页面 项目地址: https://gitcode.com/gh_mirrors/vu/v…...

Spring Cloud进阶--分布式权限校验OAuth蕉

一、核心问题及解决方案(按踩坑频率排序) 问题 1:误删他人持有锁——最基础也最易犯的漏洞 成因:释放锁时未做身份校验,直接执行 DEL 命令删除键。典型场景:服务 A 持有锁后,业务逻辑耗时超过…...

Windows系统字体自定义神器:No!! MeiryoUI 5分钟上手指南

Windows系统字体自定义神器:No!! MeiryoUI 5分钟上手指南 【免费下载链接】noMeiryoUI No!! MeiryoUI is Windows system font setting tool on Windows 8.1/10/11. 项目地址: https://gitcode.com/gh_mirrors/no/noMeiryoUI 还在为Windows 8.1/10/11单调的系…...

终极指南:3步搭建完全免费的本地语音合成神器ChatTTS-ui

终极指南:3步搭建完全免费的本地语音合成神器ChatTTS-ui 【免费下载链接】ChatTTS-ui 一个简单的本地网页界面,使用ChatTTS将文字合成为语音,同时支持对外提供API接口。A simple native web interface that uses ChatTTS to synthesize text …...

Lean 4终极指南:从定理证明到函数式编程的完整教程

Lean 4终极指南:从定理证明到函数式编程的完整教程 【免费下载链接】lean4 Lean 4 programming language and theorem prover 项目地址: https://gitcode.com/GitHub_Trending/le/lean4 Lean 4作为微软研究院开发的函数式编程语言和定理证明器,近…...

WVP-PRO流媒体服务器实战:如何优雅地自动清理无人观看的国标/代理流?

WVP-PRO流媒体服务器资源优化:无人观看流自动清理实战指南 在视频监控和流媒体服务运维中,服务器资源的高效利用是保证系统稳定运行的关键。想象一下,当你的平台同时承载数百路摄像头直播和点播回放时,那些已经无人观看却仍在消耗…...

Python敏感性分析的完整指南:SALib库的终极应用

Python敏感性分析的完整指南:SALib库的终极应用 【免费下载链接】SALib Sensitivity Analysis Library in Python. Contains Sobol, Morris, FAST, and other methods. 项目地址: https://gitcode.com/gh_mirrors/sa/SALib SALib是一个功能强大的Python库&am…...

【精】NPS内网穿透实战:从零搭建到高效管理

1. 为什么你需要NPS内网穿透? 每次出差想访问公司内网的开发环境,是不是总被VPN卡顿折磨?家里NAS里的电影想分享给朋友,却因为动态公网IP束手无策?这些问题用NPS都能轻松解决。作为一款开源的内网穿透工具&#xff0c…...

EtchDroid:让安卓手机成为你的随身启动盘制作工具,无需Root权限

EtchDroid:让安卓手机成为你的随身启动盘制作工具,无需Root权限 【免费下载链接】EtchDroid An application to write OS images to USB drives, on Android, no root required. 项目地址: https://gitcode.com/gh_mirrors/et/EtchDroid 你是否曾…...

MediaCMS权限管理实战指南:从零搭建安全媒体访问控制

MediaCMS权限管理实战指南:从零搭建安全媒体访问控制 【免费下载链接】mediacms MediaCMS is a modern, fully featured open source video and media CMS, written in Python/Django and React, featuring a REST API. 项目地址: https://gitcode.com/gh_mirrors…...

5分钟搞定YOLOv10部署:为什么这个方案最省心?

5分钟搞定YOLOv10部署:为什么这个方案最省心? 【免费下载链接】yolov10 YOLOv10: Real-Time End-to-End Object Detection [NeurIPS 2024] 项目地址: https://gitcode.com/GitHub_Trending/yo/yolov10 还在为深度学习框架的环境配置抓狂&#xf…...

Helm 入门:Kubernetes 的包管理工具

Helm 入门:Kubernetes 的包管理工具 在云原生技术快速发展的今天,Kubernetes 已成为容器编排的事实标准。随着应用规模的扩大,管理复杂的 Kubernetes 资源变得越来越繁琐。这时,Helm 作为 Kubernetes 的包管理工具应运而生&#…...

AtomGit与主流开发框架的无缝集成全指南

生态共生:AtomGit与主流开发框架的无缝集成全指南在前六篇文章中,我们已经深入掌握了AtomGit的Git操作、团队协作、CI/CD流水线、模型托管和算力连接。今天,我们将迈入一个更广阔的视角——AtomGit如何与你日常使用的开发工具、技术框架深度融…...

海南某高校xss漏洞

今天为大家分享一个最近发现的一个xss漏洞。1.在某高校官网找到领导信箱&#xff0c;然后在内容里输入xss漏洞的js测试代码(<script>alert("xss测试成功&#xff01;")</script>)测试能否执行。2.接着查询信件&#xff0c;发现可以执行&#xff0c;也就是…...

目标分解失效=Agent失控!揭秘LLM+规划器协同中3类隐性目标坍缩现象及实时校准方案

第一章&#xff1a;目标分解失效的系统性风险与架构定位 2026奇点智能技术大会(https://ml-summit.org) 目标分解是大型分布式系统演进的核心方法论&#xff0c;但当分解逻辑脱离业务语义、忽视跨域依赖或忽略可观测边界时&#xff0c;将引发级联式架构退化——微服务粒度失衡…...

Notepad--:基于Qt与Scintilla架构的跨平台文本编辑器深度解析与性能优化实践

Notepad--&#xff1a;基于Qt与Scintilla架构的跨平台文本编辑器深度解析与性能优化实践 【免费下载链接】notepad-- 一个支持windows/linux/mac的文本编辑器&#xff0c;目标是做中国人自己的编辑器&#xff0c;来自中国。 项目地址: https://gitcode.com/GitHub_Trending/n…...

APK Installer:Windows原生环境下的安卓应用部署架构与技术实现

APK Installer&#xff1a;Windows原生环境下的安卓应用部署架构与技术实现 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 在跨平台应用生态日益融合的背景下&#xf…...

Unlock Music音乐解锁工具:打破音乐平台枷锁的终极解决方案

Unlock Music音乐解锁工具&#xff1a;打破音乐平台枷锁的终极解决方案 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库&#xff1a; 1. https://github.com/unlock-music/unlock-music &#xff1b;2. https://git.unlock-music.dev/um/web 项目地址: …...

OrCAD不同版本兼容性踩坑记:为什么17.4报SPCODD-385,而16.6就没事?

OrCAD版本兼容性深度解析&#xff1a;从SPCODD-385错误看工程文件迁移策略 上周团队里新来的硬件工程师小王遇到了一个奇怪现象&#xff1a;同一份设计文件在OrCAD 17.4中报出十几个SPCODD-385错误&#xff0c;换到16.6环境却只有零星提示。这让我想起三年前公司EDA工具升级时…...

iTorrent:iPhone种子下载的终极解决方案 - 如何在iOS上轻松管理BitTorrent文件

iTorrent&#xff1a;iPhone种子下载的终极解决方案 - 如何在iOS上轻松管理BitTorrent文件 【免费下载链接】iTorrent Torrent client for iOS 16 项目地址: https://gitcode.com/gh_mirrors/it/iTorrent 想在iPhone上轻松下载和管理种子文件吗&#xff1f;iTorrent为你…...

GetQzonehistory:你的QQ空间时光机,一键导出所有青春记忆

GetQzonehistory&#xff1a;你的QQ空间时光机&#xff0c;一键导出所有青春记忆 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否曾想过&#xff0c;那些在QQ空间里记录下的青春岁…...

AIAgent上下文管理失效全归因分析(LLM推理链断裂深度复盘)

第一章&#xff1a;AIAgent上下文管理失效的系统性认知框架 2026奇点智能技术大会(https://ml-summit.org) AI Agent在真实业务场景中频繁出现“遗忘用户前序意图”“混淆多轮对话实体”“跨任务上下文污染”等现象&#xff0c;其根源并非单一模块缺陷&#xff0c;而是上下文管…...

终极指南:如何用Bliss Shader打造你的专属Minecraft电影级光影世界

终极指南&#xff1a;如何用Bliss Shader打造你的专属Minecraft电影级光影世界 【免费下载链接】Bliss-Shader A minecraft shader which is an edit of chocapic v9 项目地址: https://gitcode.com/gh_mirrors/bl/Bliss-Shader 还在为Minecraft中单调的光影效果感到乏味…...

BG3ModManager:从模组新手到管理专家的成长指南

BG3ModManager&#xff1a;从模组新手到管理专家的成长指南 【免费下载链接】BG3ModManager A mod manager for Baldurs Gate 3. This is the only official source! 项目地址: https://gitcode.com/gh_mirrors/bg/BG3ModManager 想让《博德之门3》的模组体验从混乱到有…...