news 2026/6/12 2:06:08

75_Spring AI 干货笔记之 MCP 客户端注解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
75_Spring AI 干货笔记之 MCP 客户端注解

一、MCP 客户端注解

MCP 客户端注解提供了一种使用 Java 注解来实现 MCP 客户端处理器的声明式方法。这些注解简化了服务器通知和客户端操作的处理。

所有 MCP 客户端注解必须包含一个 clients 参数,用于将处理器与特定的 MCP 客户端连接关联。该参数必须与应用程序配置文件中配置的连接名称相匹配。

二、客户端注解

2.1 @McpLogging

@McpLogging 注解用于处理来自 MCP 服务器的日志消息通知。

2.1.1 基本用法

@ComponentpublicclassLoggingHandler{@McpLogging(clients="my-mcp-server")publicvoidhandleLoggingMessage(LoggingMessageNotificationnotification){System.out.println("收到日志: "+notification.level()+" - "+notification.data());}}

2.1.2 使用独立参数

@McpLogging(clients="my-mcp-server")publicvoidhandleLoggingWithParams(LoggingLevellevel,Stringlogger,Stringdata){System.out.println(String.format("[%s] %s: %s",level,logger,data));}

2.2 @McpSampling

@McpSampling 注解用于处理来自 MCP 服务器的大语言模型补全采样请求。

2.2.1 同步实现

@ComponentpublicclassSamplingHandler{@McpSampling(clients="llm-server")publicCreateMessageResulthandleSamplingRequest(CreateMessageRequestrequest){// 处理请求并生成响应Stringresponse=generateLLMResponse(request);returnCreateMessageResult.builder().role(Role.ASSISTANT).content(newTextContent(response)).model("gpt-4").build();}}

2.2.2 异步实现

@ComponentpublicclassAsyncSamplingHandler{@McpSampling(clients="llm-server")publicMono<CreateMessageResult>handleAsyncSampling(CreateMessageRequestrequest){returnMono.fromCallable(()->{Stringresponse=generateLLMResponse(request);returnCreateMessageResult.builder().role(Role.ASSISTANT).content(newTextContent(response)).model("gpt-4").build();}).subscribeOn(Schedulers.boundedElastic());}}

2.3 @McpElicitation

@McpElicitation 注解用于处理向用户收集额外信息的征询请求。

2.3.1 基本用法

@ComponentpublicclassElicitationHandler{@McpElicitation(clients="interactive-server")publicElicitResulthandleElicitationRequest(ElicitRequestrequest){// 向用户展示请求并收集输入Map<String,Object>userData=
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 22:46:22

分布式训练太难?verl的HybridFlow编程真香了

分布式训练太难&#xff1f;verl的HybridFlow编程真香了 1. 为什么RLHF分布式训练让人头疼——从痛点出发的真实体验 你有没有试过用传统RL框架训练一个7B参数的大模型&#xff1f;不是跑不起来&#xff0c;而是跑得“心累”。 想加一个新奖励函数&#xff1f;得改三处代码、…

作者头像 李华
网站建设 2026/5/30 22:15:39

训练自己的OCR模型?科哥镜像支持微调,操作很简单

训练自己的OCR模型&#xff1f;科哥镜像支持微调&#xff0c;操作很简单 你是不是也遇到过这些情况&#xff1a; 现成的OCR服务识别不准&#xff0c;尤其在自己业务场景里——比如产品包装上的小字号、带阴影的标签、手写批注&#xff1b;用公开API担心数据外泄&#xff0c;又…

作者头像 李华
网站建设 2026/5/28 17:42:03

LVGL界面编辑器滚动区域布局从零实现

以下是对您提供的博文内容进行 深度润色与重构后的技术文章 。全文已彻底去除AI生成痕迹、模板化表达和教科书式结构,转而以一位 深耕LVGL多年、常年在STM32/ESP32项目一线调试滚动UI的嵌入式GUI工程师口吻 重新组织——语言更自然、逻辑更递进、重点更锋利,兼具教学性与…

作者头像 李华
网站建设 2026/6/10 13:28:22

为什么选择Paraformer?离线语音识别最佳实践分享

为什么选择Paraformer&#xff1f;离线语音识别最佳实践分享 在会议纪要整理、课程录音转写、访谈内容归档等日常工作中&#xff0c;你是否也经历过这样的困扰&#xff1a;上传一段30分钟的讲座音频&#xff0c;等了5分钟却只返回“服务超时”&#xff1b;或者用在线API识别&a…

作者头像 李华
网站建设 2026/6/3 3:15:00

Qwen3-1.7B微调教程:10GB显存搞定专业领域适配

Qwen3-1.7B微调教程&#xff1a;10GB显存搞定专业领域适配 1. 为什么这次微调真的不难&#xff1f; 你可能已经试过几次大模型微调——下载权重、配置环境、改LoRA参数、等半天训练完发现显存爆了&#xff0c;或者效果差得连自己写的prompt都认不出来。Qwen3-1.7B不一样。它不…

作者头像 李华
网站建设 2026/5/28 17:42:10

手把手教你用YOLOv10镜像做工业视觉检测

手把手教你用YOLOv10镜像做工业视觉检测 在汽车零部件质检线上&#xff0c;一台工控机正以每秒27帧的速度处理高清图像——螺丝是否拧紧、垫片有无缺失、焊缝是否存在气孔&#xff0c;所有判断都在毫秒间完成。这不是实验室里的Demo&#xff0c;而是今天许多工厂车间里正在运行…

作者头像 李华