SpringAI MCP

课程笔记

MCP(模型上下文协议)

之前SpringAI中每一个tool都需要自己编写,MCP提供了一个统一的协议,这样所有人都可以按照这个协议来编写工具,模型也可以按照这个协议来调用工具,形成一个生态系统。

我们想用的时候直接去调用他们写好的工具就行了,不需要自己再写一遍了。一般把工具用server来提供出来,所以我们只要搭建一个client去链接他们的server就行了。如图:

MCP工具查询网站可以查询有什么工具,工具的调用方式等信息。

入门

可以把之前的时间工具改成MCP Server的形式,提供一个接口让别人调用,作为入门案例。

MCP Server

新建项目,依赖

xml 复制代码
<dependency>
   <groupId>org.springframework.ai</groupId>
   <artifactId>spring-ai-starter-mcp-server-webflux</artifactId>
</dependency>
<dependency>
   <groupId>org.springframework</groupId>
   <artifactId>spring-web</artifactId>
</dependency>
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter</artifactId>
</dependency>
java 复制代码
@Configuration
public class McpConfig {
   @Bean
   public ToolCallbackProvider weatherTools(TimeTools tools) {
       return MethodToolCallbackProvider.builder().toolObjects(tools).build();
   }
}

MCP Client

依赖:

xml 复制代码
dependency>
  <groupId>org.springframework.ai</groupId>
  <artifactId>spring-ai-starter-mcp-client-webflux</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>

配置文件

yaml 复制代码
spring:
  ai:
    zhipuai:
      api-key: 你的apikey
    mcp:
      client:
        sse:
          connections:
            server1:
              url: http://localhost:8080 # mcp服务url
  http:
    client:
      read-timeout: 100000
server:
  port: 8081

Controller

java 复制代码
public CoffeeController(VectorStore vectorStore, ChatClient.Builder chatClientBuilder, ToolCallbackProvider toolCallbackProvider) {
        this.vectorStore = vectorStore;
        VectorStoreDocumentRetriever vectorStoreDocumentRetriever = VectorStoreDocumentRetriever.builder()
                .vectorStore(vectorStore)
                .topK(3)
                .similarityThreshold(0.5)
                .build();
        RetrievalAugmentationAdvisor retrievalAugmentationAdvisor = RetrievalAugmentationAdvisor.builder()
                .documentRetriever(vectorStoreDocumentRetriever)
                .build();

        this.chatClient = chatClientBuilder.defaultAdvisors(retrievalAugmentationAdvisor)
               .defaultToolCallbacks(toolCallbackProvider.getToolCallbacks())
               .build();
    }

网页抓取MCP server

MCP server部署

在服务器上

yaml 复制代码
version: "3.8"
services:
   fetcher-mcp:
      image: ghcr.io/jae-jae/fetcher-mcp:latest
      container_name: fetcher-mcp
      restart: unless-stopped
      ports:
         - "3000:3000"
      environment:
         - NODE_ENV=production
      # Using host network mode on Linux hosts can improve browser access efficiency
      # network_mode: "host"
      volumes:
       # For Playwright, may need to share certain system paths
         - /tmp:/tmp
      # Health check
      healthcheck:
         test: ["CMD", "wget", "--spider", "-q", "http://localhost:3000"]
         interval: 30s
         timeout: 10s
         retries: 3

在这个文件所在目录下运行docker-compose up -d命令启动服务。

MCP client调用

配置文件

yaml 复制代码
spring:
  ai:
    zhipuai:
      api-key: 你的API

  mcp:
   client:
     sse:
       connections:
         server1:
           url: http://localhost:8080 # mcp服务url
         fetcher-mcp:
           url: http://自己的ip地址:3000
java 复制代码
@GetMapping("/fetcher")
public String fetcher(String question) {
  return chatClient.prompt()
          .system("你是一个网页爬取专家,你可以运用工具爬取指定网页的内容并且进行总结")
          .user(question)
          .call().content();
}
相关推荐
一条泥憨鱼1 小时前
深入理解2026AI最大公约数:Agent
开发语言·人工智能·ai·agent
码农阿强1 小时前
Qwen3.7-Max技术特性解析及调用实践
人工智能·ai·aigc·ai编程
苦逼的猿宝1 小时前
基于SpringBoot的旅游网站的设计与实现(源码+论文)
java·毕业设计·springboot·计算机毕业设计
_codemonster1 小时前
JSP 、Thymeleaf 、 JavaScript 和Vue
java·javascript·vue.js
Devin~Y1 小时前
大厂Java面试实录:Spring Boot微服务 + Redis缓存 + Kafka消息队列 + Prometheus链路追踪 + RAG向量检索
java·spring boot·redis·spring cloud·kafka·rabbitmq·spring mvc
武子康1 小时前
调查研究-142 全球机器人产业深度调研报告【04篇】机器人产业利润池全景:谁最容易赚钱与十大判断指标
大数据·人工智能·ai·机器人·具身智能·openclaw
Oj92q85H51 小时前
如何在Dev-C++中设置TDM-GCC为默认编译器
java·jvm·c++
逸Y 仙X1 小时前
文章二:Elasticsearch跨集群能力探查
java·大数据·服务器·elasticsearch·搜索引擎·全文检索
阿标在干嘛1 小时前
政策快报如何让推荐准确率从8%提升到16%?画像系统实践
java·大数据·人工智能