news 2026/5/6 20:01:34

MCP Server 运行模式入门(Streamable HTTP / stdio)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MCP Server 运行模式入门(Streamable HTTP / stdio)

MCP Server 运行模式入门(Streamable HTTP / stdio)

目标:把你当前项目里“关键类/方法/字段”与 MCP 协议运行流程对上号,尽量解释“它在做什么、为什么需要它”。

目录

  • 一、Streamable HTTP 模式(基于 WebFlux)
  • 二、stdio 模式(基于标准输入输出)
  • 三、两种模式对比与选型
  • 四、项目内关键类逐段解读(对照源码)
  • 五、常见疑问与排查思路

一、Streamable HTTP 模式(基于 WebFlux)

1. 适用场景

  • 需要把 MCP Server 作为常驻服务部署(本机、服务器、容器)。
  • 需要通过HTTP接入(便于反向代理、网关、HTTPS、负载均衡)。
  • 多客户端或并发调用场景更合适。

2. 核心概念

  • Streamable HTTP:MCP 的一种传输方式,统一通过单一 HTTP 端点传输消息。
  • 端点:例如/mcp/message,客户端在此进行初始化、调用工具与接收服务端推送。
  • WebFlux:Spring 的响应式 Web 容器,用于承载 Streamable HTTP 的路由与流式消息。

3. 运行流程(概念图)

MCP Server (WebFlux)MCP ClientMCP Server (WebFlux)MCP ClientHTTP POST /mcp/message (initialize)1initialize response (capabilities)2HTTP POST /mcp/message (tool call)3tool result / streaming events4

4. 关键配置项(你的项目里)

  • spring.ai.mcp.server.stdio=false
    • 含义:关闭 stdio,启用 HTTP 传输。
  • spring.main.web-application-type=reactive
    • 含义:使用 WebFlux 作为容器。
  • spring.ai.mcp.server.sse-message-endpoint=/mcp/message
    • 含义:Streamable HTTP 端点路径。
  • server.port=8101
    • 含义:HTTP 服务监听端口。

5. WebFlux 与 MVC 的区别(简要对比)

维度WebFluxSpring MVC
编程模型响应式(Reactive Streams)同步阻塞
线程模型少量线程处理大量连接一请求一线程
适合场景高并发、流式传输、SSE传统表单/REST、同步调用
依赖容器Netty/响应式容器Servlet 容器
MCP 适配Streamable HTTP 更自然需要额外适配或走 stdio

二、stdio 模式(基于标准输入输出)

1. 适用场景

  • MCP Server 不需要暴露 HTTP 服务,仅在本机被 MCP Client 调用。
  • 更适合开发调试、小工具、单用户场景。

2. 核心概念

  • stdio:MCP Client 拉起 MCP Server 进程,通过 stdin/stdout 进行 JSON-RPC 通信。
  • 进程生命周期:通常由客户端控制,客户端启动时拉起,结束时退出。

3. 运行流程(概念图)

MCP Server (stdio)MCP ClientMCP Server (stdio)MCP Client启动服务端进程1stdin 写入 initialize2stdout 返回 capabilities3stdin 写入 tool call4stdout 返回结果5关闭进程6

4. 关键配置项(思路说明)

  • spring.ai.mcp.server.stdio=true
    • 含义:启用 stdio 模式。
  • spring.main.web-application-type=none
    • 含义:不启动 Web 容器。

三、两种模式对比与选型

维度Streamable HTTPstdio
通信方式HTTP 单端点流式stdin/stdout
部署形态常驻服务被客户端拉起
并发能力一般
网络要求需要端口无需端口
适用场景多用户/生产单机/开发

四、项目内关键类逐段解读(对照源码)

下面按你项目里的核心类解释“它的意义”和“它做了什么”。

1.StreamableMcpServerConfiguration

文件mcp-core/src/main/java/com/xbk/mcp/server/infrastructure/mcp/StreamableMcpServerConfiguration.java

(1) 类级别注解
  • @Configuration
    • 标识这是 Spring 配置类,负责创建 Bean。
  • @EnableConfigurationProperties(McpServerProperties.class)
    • 绑定spring.ai.mcp.server.*配置。
  • @ConditionalOnClass(...)
    • 只有当 MCP + WebFlux 相关类存在时才启用(避免缺依赖启动失败)。
  • @ConditionalOnExpression("${spring.ai.mcp.server.enabled:true} && !${spring.ai.mcp.server.stdio:true}")
    • 配置启用 MCP 且 stdio 关闭时,才启用 Streamable HTTP。
(2)streamableServerTransportProvider(...)
  • 作用:提供 Streamable HTTP 传输实现
  • 关键点:读取sseMessageEndpoint(默认/mcp/message),并构建 WebFlux 传输提供器。
(3)mcpStreamableRouterFunction(...)
  • 作用:把 MCP 的 HTTP 路由注册到 WebFlux 中。
  • 结果:WebFlux 会把/mcp/message交给 MCP 处理。
(4)mcpServerCapabilitiesBuilder()
  • 作用:创建 MCP ServerCapabilities 的 Builder。
  • 结果:后续会把“工具/资源/提示”能力声明进去。
(5)mcpStreamableSyncServer(...)
  • 作用:创建 MCP Server 实例并注册能力
  • 具体流程:
    1. 组装serverInfo(名称、版本)。
    2. 创建McpServer.sync(transportProvider)
    3. 从 Spring 容器里收集 Tool/Resource/Prompt。
    4. 注册到serverBuilder
    5. 设置capabilitiesBuilder
    6. build()生成 MCP Server。
(6) 关键字段含义
  • McpStreamableServerTransportProvider transportProvider
    • HTTP 传输层(Streamable HTTP),负责消息通道。
  • McpSchema.ServerCapabilities.Builder capabilitiesBuilder
    • MCP 服务端能力声明。
  • ObjectProvider<List<ToolCallback>> toolCallbacksProvider
    • Spring 容器里所有 @McpTool 形成的回调。

2.McpServerProperties

文件mcp-core/src/main/java/com/xbk/mcp/server/infrastructure/mcp/McpServerProperties.java

  • enabled:是否启用 MCP Server。
  • name/version:用于 initialize 返回的服务端标识。
  • stdio:是否走 stdio 传输。
  • sseMessageEndpoint:Streamable HTTP 端点。
  • toolChangeNotification/resourceChangeNotification/promptChangeNotification:能力变更通知开关。

3.HttpClientLogInterceptor

文件mcp-core/src/main/java/com/xbk/mcp/server/infrastructure/logging/HttpClientLogInterceptor.java

  • 作用:统一记录外部 HTTP 请求的请求头、请求体、响应体、耗时。
  • 关键点:
    • requestBody:读取并压成单行日志。
    • response.peekBody(...):读取响应,不消费原始响应流。
    • toSingleLine:把换行替换成\\n以保证日志单行。

4.CsdnToolApplication

文件mcp-tool-csdn/src/main/java/com/xbk/mcp/server/CsdnToolApplication.java

  • 作用:启动 MCP Server(CSDN 模块)并输出启动日志。
  • 说明:它不直接管 MCP 逻辑,真正的 MCP Server 在mcp-core里装配。

五、常见疑问与排查思路

1. Claude Code 显示not authenticated

  • 通常是 MCP 配置 schema 不匹配(type写错、url未指向/mcp/message)。

2. 日志出现协议版本警告

  • 客户端与服务端支持版本不一致,一般会降级继续运行。

3. 工具调用不上

  • 检查:
    • @McpTool是否被扫描到
    • 服务端是否启用了 MCP
    • Tool 是否在容器里生成 Bean

备注:如果你希望“对照源码逐行讲解”

你可以告诉我你最不理解的类或方法,我可以进一步拆成“每一段在做什么”。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/4 0:11:10

从入门到高手:DownKyi视频下载的3×5实战指南

从入门到高手&#xff1a;DownKyi视频下载的35实战指南 【免费下载链接】downkyi 哔哩下载姬downkyi&#xff0c;哔哩哔哩网站视频下载工具&#xff0c;支持批量下载&#xff0c;支持8K、HDR、杜比视界&#xff0c;提供工具箱&#xff08;音视频提取、去水印等&#xff09;。 …

作者头像 李华
网站建设 2026/5/4 1:37:45

RMBG-2.0模型结构解读:BiRefNet双边参考机制如何提升精度

RMBG-2.0模型结构解读&#xff1a;BiRefNet双边参考机制如何提升精度 1. 为什么我们需要更精准的背景移除&#xff1f; 你有没有遇到过这样的情况&#xff1a;花十分钟用PS抠一张人像&#xff0c;结果发丝边缘还是毛毛躁躁&#xff1b;上传商品图到电商后台&#xff0c;系统自…

作者头像 李华
网站建设 2026/5/5 0:14:09

从零实现跨arm64 x64平台的ABI适配层示例

以下是对您提供的博文内容进行 深度润色与工程化重构后的版本 。我以一位长期深耕嵌入式系统、跨平台运行时及底层 ABI 设计的工程师视角,彻底重写了全文—— 去除所有AI腔调、模板化结构和空泛术语堆砌,代之以真实开发中踩过的坑、权衡过的取舍、验证过的数据,以及可直接…

作者头像 李华
网站建设 2026/5/1 16:49:49

多任务自动化:一个指令完成多个手机操作

多任务自动化&#xff1a;一个指令完成多个手机操作 摘要&#xff1a;本文带你用一句话让手机自动完成一连串操作——打开App、搜索内容、点击按钮、输入文字、滑动页面、发送消息……全程无需手动干预。基于智谱开源的 Open-AutoGLM 框架&#xff0c;我们不讲抽象原理&#xf…

作者头像 李华
网站建设 2026/4/25 8:07:24

DeepChat深度体验:基于Llama3的智能对话系统效果实测

DeepChat深度体验&#xff1a;基于Llama3的智能对话系统效果实测 最近在本地部署AI对话服务时&#xff0c;反复被几个问题困扰&#xff1a;模型响应慢、隐私难保障、启动总报错、界面太简陋……直到试用「&#x1f9e0; DeepChat - 深度对话引擎」镜像&#xff0c;才真正体会到…

作者头像 李华