news 2026/6/10 13:13:31

SpringAI-mcp-sse方式

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SpringAI-mcp-sse方式

1.什么是SSE

Server-Sent Events 是基于 HTTP 协议的实时单向服务器推送技术,具有轻量级、⾃动重连和事 件分类型特点,适⽤于实时数据推送场景。允许服务器主动向客户端(如浏览器)推送实时数据。与 传统的轮询或⻓轮询不同, SSE 通过单⼀的持久连接实现数据的实时传输,客户端⽆需频繁发起请求。

2.SSE的特点

  • 单向通信
    • SSE 是单向的,服务器可以主动推送数据到客户端,但客户端⽆法直接通过 SSE 向服 务器发送数据。
  • 基于 HTTP 协议
    • SSE 使⽤标准的 HTTP 协议,⽆需额外的协议或端⼝配置,兼容性好,易于实现。
  • 轻量级
    • 相⽐ WebSocket , SSE 的实现更简单,代码量更少,适合简单的实时数据推送场景。
  • ⾃动重连
    • 如果连接断开,浏览器会⾃动尝试重新连接,开发者⽆需⼿动处理重连逻辑。
  • ⽀持事件类型
    • 服务器可以发送不同类型的事件,客户端可以根据事件类型执⾏不同的操作。
  • 支持消息 ID
    • 每条消息可以包含⼀个唯⼀的 ID ,⽤于断线重连后恢复消息流。

3.SSE工作原理

相⽐传统的请求-响应模式, SSE 提供了⼀种持久连接,允许服务器随时向客户端发送事件和 数据,实现了实时性的消息传递。 SSE 的⼯作原理⾮常简单直观。客户端通过与服务器建⽴⼀条持久化的 HTTP 连接,然后服 务器使⽤该连接将数据以事件流(event stream)的形式发送给客户端。这些事件流由多个 事件( event )组成,每个事件包含⼀个标识符、类型和数据字段。客户端通过监听事件流 来获取最新的数据,并在接收到事件后进⾏处理。

4.SSE应用场景

服务端想主动向客户端发送回音

5.搭建服务器

5.1导依赖

<dependencies> <dependency> <groupId>org.springframework.ai</groupId> <artifactId>spring-ai-starter-mcp-server-webmvc</artifactId> </dependency> </dependencies>

5.2书写配置

server: port: 8011 spring: application: name: ai-mcp-sse-server ai: mcp: server: name: ai-mcp-sse-server sse-message-endpoint: /mcp/city

5.3开发工具

package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.sse.server.service; import org.springframework.stereotype.Service; @Service public interface CityService { String city(); }
package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.sse.server.service.impl; import com.jiazhong.mingxing.ai.siliconflow.glm.mcp.sse.server.service.CityService; import org.springframework.ai.tool.annotation.Tool; import org.springframework.stereotype.Service; @Service public class CityServiceImpl implements CityService { @Tool(description = "中国最宜居的城市",name = "cityService") public String city() { return "青岛:北方宜居标杆,中科院 2024 宜居榜首。属于温带海洋性气候,四季分明,湿度适中。海岸线长达 817 公里,绿化覆盖率达 41%,空气优良率常年超 92%。拥有 12 家三甲医院,以及青岛大学、中国海洋大学等高校,地铁运营里程超 400 公里。"; } }

5.4注册服务

package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.sse.server.config; import com.jiazhong.mingxing.ai.siliconflow.glm.mcp.sse.server.service.CityService; import jakarta.annotation.Resource; import org.springframework.ai.tool.ToolCallbackProvider; import org.springframework.ai.tool.method.MethodToolCallbackProvider; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class ServiceConfig { @Resource private CityService cityService; @Bean("toolCallbackProvider") public ToolCallbackProvider toolCallbackProvider(){ return MethodToolCallbackProvider.builder().toolObjects(cityService).build(); } }

5.5启动项

package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.sse.server; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class AiSiliconflowGlmMcpSseServerApplication { public static void main(String[] args) { SpringApplication.run(AiSiliconflowGlmMcpSseServerApplication.class,args); } }

6.搭建客户端

6.1导依赖

<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.ai</groupId> <artifactId>spring-ai-starter-model-openai</artifactId> </dependency> <dependency> <groupId>org.springframework.ai</groupId> <artifactId>spring-ai-starter-mcp-client</artifactId> </dependency> </dependencies>

6.2配置文件

server: port: 8012 spring: application: name: ai-siliconflow-glm-mcp-sse-client ai: openai: base-url: https://api.siliconflow.cn api-key: 你的轨迹流动的的key chat: options: model: "zai-org/GLM-4.6" temperature: 0.7 mcp: client: name: ai-siliconflow-glm-mcp-sse-client sse: connections: server1: url: http://localhost:8011 #要连接服务器的地址 (先启动服务区后启动客户端) toolcallback: enabled: true

6.3配置类

package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.sse.client.config; import jakarta.annotation.Resource; import org.springframework.ai.chat.client.ChatClient; import org.springframework.ai.openai.OpenAiChatModel; import org.springframework.ai.tool.ToolCallbackProvider; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class ChatClientConfig { @Resource private OpenAiChatModel openAiChatModel; @Resource private ToolCallbackProvider toolCallbackProvider; @Bean("openAiChatClient") public ChatClient openAiChatClient(){ return ChatClient.builder(openAiChatModel) .defaultToolCallbacks(toolCallbackProvider) .build(); } }

6.4controller类

package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.sse.client.controller; import jakarta.annotation.Resource; import org.springframework.ai.chat.client.ChatClient; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import reactor.core.publisher.Flux; @RestController @RequestMapping("/city_client") public class CityClientController { @Resource private ChatClient openAiChatClient; @GetMapping(value = "/a",produces = "text/html;charset=utf-8") public Flux<String> a(@RequestParam("question") String question){ return openAiChatClient.prompt() .user(question) .stream().content(); } }

6.5启动类

package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.sse.client; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class AiSiliconflowGlmMcpSseClientApplication { public static void main(String[] args) { SpringApplication.run(AiSiliconflowGlmMcpSseClientApplication.class,args); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 10:55:20

小白也能懂的verl教程:快速搭建LLM后训练系统

小白也能懂的verl教程&#xff1a;快速搭建LLM后训练系统 1. 这不是又一个“高不可攀”的强化学习框架 你可能已经看过太多关于LLM强化学习的介绍&#xff1a;PPO、KL散度、奖励建模、Actor-Critic……每个词都像一堵墙&#xff0c;把想动手实践的人挡在外面。更别说还要配环…

作者头像 李华
网站建设 2026/6/10 10:57:29

Local AI MusicGen智能助手:自动化音效生成系统

Local AI MusicGen智能助手&#xff1a;自动化音效生成系统 1. 你的私人AI作曲家&#xff0c;现在就能在本地运行 &#x1f3b5; Local AI MusicGen 这不是云端等待排队的音乐生成服务&#xff0c;而是一个真正属于你自己的、离线可用的AI音乐工作台。它不依赖网络连接&#…

作者头像 李华
网站建设 2026/6/4 1:58:35

鼠标精准控制与游戏体验优化:Raw Accel专业设置指南

鼠标精准控制与游戏体验优化&#xff1a;Raw Accel专业设置指南 【免费下载链接】rawaccel kernel mode mouse accel 项目地址: https://gitcode.com/gh_mirrors/ra/rawaccel 在数字交互中&#xff0c;鼠标作为最直接的输入设备&#xff0c;其响应特性直接影响操作精度与…

作者头像 李华
网站建设 2026/6/10 8:14:46

提升Qwen3-0.6B训练稳定性,这几个参数很关键

提升Qwen3-0.6B训练稳定性&#xff0c;这几个参数很关键 在实际微调Qwen3-0.6B模型的过程中&#xff0c;很多开发者会遇到训练初期loss剧烈震荡、梯度爆炸、显存OOM、收敛缓慢甚至直接崩溃等问题。这些问题往往不是模型能力不足导致的&#xff0c;而是几个关键训练参数设置不当…

作者头像 李华