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();
}
相关推荐
小bo波8 小时前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing
咖啡八杯10 小时前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
SamDeepThinking20 小时前
裁掉那个差程序员后,给你看团队里高手的代码:这个习惯,希望你有
java·后端·程序员
朕瞧着你甚好21 小时前
技术雷达 & Java 集成评估报告 — Apache Tika 3.3.1
java·ai编程
MacroZheng1 天前
短短几天,暴涨2.8万Star!又一款编程神器开源!
java·人工智能·后端
SamDeepThinking1 天前
函数式编程:用BiFunction消除多类型分支的代码重复
java·后端·面试
doiito1 天前
【Agent Harness】Gliding Horse L2 作战地图深度优化:给多 Agent 上下文装上“精准导航”
ai·rust·架构设计·系统设计·ai agent
妙妙屋(zy)2 天前
Claude Code+CC-Switch+CC-Connect+飞书使用教程
ai
Flittly2 天前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了2 天前
Java 生成二维码解决方案
java·后端