Spring AI文档学习:多聊天模型配置

前置:application.yml(阿里云百炼作为 OpenAI 兼容端点)

yaml 复制代码
spring:
  ai:
    openai:
      api-key: ${DASHSCOPE_API_KEY}
      base-url: https://dashscope.aliyuncs.com/compatible-mode/v1
      chat:
        options:
          model: qwen-plus

说明:api-key 使用百炼控制台里的 API Key;model 用百炼里在「OpenAI 兼容」下支持的模型名(如 qwen-plusqwen-max 等,以控制台为准)。

方法一:同一模型类型(都是 OpenAiChatModel / 百炼),多个 ChatClient

差别只在 ChatClient 层默认行为(例如不同系统提示),底层仍是同一个注入的 OpenAiChatModel

kotlin 复制代码
import org.springframework.ai.chat.client.ChatClient;
import org.springframework.ai.openai.OpenAiChatModel;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class BailianMultiClientConfig {

    @Bean
    public ChatClient conciseBailianClient(OpenAiChatModel chatModel) {
        return ChatClient.builder(chatModel)
                .defaultSystem("你是简洁助手,回答尽量短。")
                .build();
    }

    @Bean
    public ChatClient detailedBailianClient(OpenAiChatModel chatModel) {
        return ChatClient.builder(chatModel)
                .defaultSystem("你是详细助手,先列要点再展开。")
                .build();
    }
}

@Qualifier("conciseBailianClient") / @Qualifier("detailedBailianClient") 注入即可。

方法二:不同模型类型,多个 ChatClient(百炼 OpenAI 兼容 + 另一家)

这里 第一类仍是百炼(OpenAiChatModel + 上面 yml)。第二类换厂商时用另一种 ChatModel(示例用 Anthropic;需引入对应 Spring AI starter 并配置密钥)。

kotlin 复制代码
import org.springframework.ai.anthropic.AnthropicChatModel;
import org.springframework.ai.chat.client.ChatClient;
import org.springframework.ai.openai.OpenAiChatModel;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MultiVendorChatClientConfig {

    /** 百炼:OpenAI 兼容,底层是 OpenAiChatModel */
    @Bean
    public ChatClient bailianChatClient(OpenAiChatModel openAiChatModel) {
        return ChatClient.builder(openAiChatModel)
                .defaultSystem("你通过阿里云百炼(OpenAI 兼容)回答问题。")
                .build();
    }

    /** 另一家:原生 Anthropic API */
    @Bean
    public ChatClient anthropicChatClient(AnthropicChatModel anthropicChatModel) {
        return ChatClient.builder(anthropicChatModel)
                .defaultSystem("你通过 Anthropic API 回答问题。")
                .build();
    }
}

要点:百炼走 OpenAI 兼容 → OpenAiChatModel;Anthropic 走自己的 AnthropicChatModel,这是「不同模型类型」在 Spring AI 里的典型拆法。

方法三:多个 OpenAI 兼容端点(百炼 + 另一个 OpenAI 兼容服务)

仍只用 OpenAiApi / OpenAiChatModel,通过 mutate()baseUrlapiKey、默认 model。第二个端点可以是:官方 OpenAI、Groq、其它国内兼容网关等,协议形状与 OpenAI 一致即可。

scss 复制代码
import org.springframework.ai.chat.client.ChatClient;
import org.springframework.ai.openai.OpenAiChatModel;
import org.springframework.ai.openai.api.OpenAiApi;
import org.springframework.ai.openai.OpenAiChatOptions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class MultiOpenAiCompatibleEndpointsService {

    @Autowired
    private OpenAiChatModel baseChatModel;

    @Autowired
    private OpenAiApi baseOpenAiApi;

    public void compareTwoEndpoints(String userMessage) {
        // 端点 A:阿里云百炼(北京 OpenAI 兼容)
        OpenAiApi bailianApi = baseOpenAiApi.mutate()
                .baseUrl("https://dashscope.aliyuncs.com/compatible-mode/v1")
                .apiKey(System.getenv("DASHSCOPE_API_KEY"))
                .build();

        OpenAiChatModel bailianModel = baseChatModel.mutate()
                .openAiApi(bailianApi)
                .defaultOptions(OpenAiChatOptions.builder()
                        .model("qwen-plus")
                        .temperature(0.3)
                        .build())
                .build();

        // 端点 B:另一个 OpenAI 兼容服务(示例:请换成你真实的 URL / Key / 模型名)
        OpenAiApi otherApi = baseOpenAiApi.mutate()
                .baseUrl("https://api.openai.com/v1")  // 或其它兼容网关
                .apiKey(System.getenv("OPENAI_API_KEY"))
                .build();

        OpenAiChatModel otherModel = baseChatModel.mutate()
                .openAiApi(otherApi)
                .defaultOptions(OpenAiChatOptions.builder()
                        .model("gpt-4o-mini")
                        .temperature(0.3)
                        .build())
                .build();

        String r1 = ChatClient.builder(bailianModel).build()
                .prompt(userMessage).call().content();
        String r2 = ChatClient.builder(otherModel).build()
                .prompt(userMessage).call().content();

        // 使用 r1 / r2
    }
}

若两个都是百炼,只是 地域或模型不同,把「端点 B」改成例如新加坡兼容地址,并只改 model 即可

相关推荐
Ruihong1 小时前
你的 Vue 3 defineAsyncComponent(),VuReact 会编译成什么样的 React?
vue.js·react.js·面试
Ruihong1 小时前
你的 Vue 路由,VuReact 会编译成什么样的 React 路由?
vue.js·react.js·面试
Moe4881 小时前
Spring AI(1.1.0):消息元数据
java·后端·面试
用户3721574261351 小时前
Python 实现 Word 转 HTML 的三种方法
后端
AI进阶客栈1 小时前
AI 幻觉与 RAG 技术详解:原理 + Spring Boot + pgvector 实战教程
人工智能·spring boot·后端
aXin_ya1 小时前
微服务 第三天
java·微服务·架构
掘金者阿豪2 小时前
AI视频生成大模型大战:Happy Horse 硬刚 Doubao Seedance,1秒1块钱的视频时代来了
后端
掘金者阿豪2 小时前
程序员破防现场:Codex 配置自定义 AI API 后,Token 为什么烧得这么快?我的血汗钱啊!
后端
董董灿是个攻城狮2 小时前
MinMax 发布会进化的 AI 助手,有点强
后端