使用spring-ai-alibaba接入大模型

  spring-ai-alibaba 是Spring AI生态里与阿里巴巴相关的组件,借助它能够实现接入各类大模型。以下为你详细介绍如何使用 spring-ai-alibaba 接入不同大模型:

接入open ai

项目环境准备

        首先要创建一个Spring Boot项目,并且在 pom.xml 里添加必要的依赖。接入openapi为例(我这里使用硅基流动和openapi一样)官网:SiliconFlow

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.5.0</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.sqz</groupId>
    <artifactId>spring-ai-deepseek</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>spring-ai-deepseek</name>
    <description>spring-ai-deepseek</description>
    <url/>
    <licenses>
        <license/>
    </licenses>
    <developers>
        <developer/>
    </developers>
    <scm>
        <connection/>
        <developerConnection/>
        <tag/>
        <url/>
    </scm>
    <properties>
        <java.version>21</java.version>
    </properties>
    <dependencies>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--接入openapi-->
        <dependency>
            <groupId>org.springframework.ai</groupId>
            <artifactId>spring-ai-openai-spring-boot-starter</artifactId>
            <version>1.0.0-M6</version>
        </dependency>

       <!--接入ollama-->
        <!--
          <dependency>
                  <groupId>org.springframework.ai</groupId>
                  <artifactId>spring-ai-ollama-spring-boot-starter</artifactId>
                  <version>1.0.0-M6</version>
          </dependency>
          -->
            <!--接入 通义千问-->
            <!--   <dependency>
                    <groupId>com.alibaba.cloud.ai</groupId>
                  <artifactId>spring-ai-alibaba-starter</artifactId>
                   <version>1.0.0-M6.1</version>
               </dependency>
             -->


        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
    <repositories>
        <repository>
            <id>spring-milestones</id>
            <name>Spring Milestones</name>
            <url>https://repo.spring.io/milestone</url>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </repository>
        <repository>
            <id>spring-snapshots</id>
            <name>Spring Snapshots</name>
            <url>https://repo.spring.io/snapshot</url>
            <releases>
                <enabled>false</enabled>
            </releases>
        </repository>
        <repository>
            <id>aliyunmaven</id>
            <name>aliyun</name>
            <url>https://maven.aliyun.com/repository/public</url>
        </repository>
    </repositories>

    <pluginRepositories>
        <pluginRepository>
            <id>public</id>
            <name>aliyun nexus</name>
            <url>https://maven.aliyun.com/repository/public</url>
            <releases>
                <enabled>true</enabled>
            </releases>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </pluginRepository>
    </pluginRepositories>
</project>

配置认证信息

在 application.properties 或者 application.yml 中配置硅基流动认证信息,例如:

spring:
  application:
    name: alibaba-ai-demo
  ai:
    openai:
      api-key: your-api-key  #apiKey到硅基流动官网获取免费的
      base-url: https://api.siliconflow.cn
      chat:
        options:
          model: Qwen/QwQ-32B  #使用通义千问模型

这里的 your-api-key 要替换成自己获取的API Key。

 编写代码接入大模型

下面是一个简单的Java代码示例,展示了如何使用 spring-ai-alibaba 接入openapi模型:

package com.sqz.springaideepseek.controller;

import org.springframework.ai.chat.client.ChatClient;
import org.springframework.http.MediaType;
import org.springframework.http.codec.ServerSentEvent;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import reactor.core.publisher.Flux;

@RestController
public class ChatController {

    private final ChatClient chatClient;

    public ChatController(ChatClient.Builder builder) {
        this.chatClient = builder
                .defaultSystem("你是一个万能助手,你可以回答任何问题。")
                .build();
    }

    @GetMapping("/chat")
    public String chat(@RequestParam(value = "input") String input) {

        return this.chatClient.prompt()
                .user(input)
                .call()
                .content();
    }

    /**
     * ChatClient 流式响应
     */
    @GetMapping(value = "/stream/response", produces =  "text/event-stream;charset=UTF-8")
    public Flux<ServerSentEvent<String>> simpleChat(@RequestParam String message) {
        return chatClient.prompt()
                .user(message)
                .stream()
                .content()
                .map(content -> ServerSentEvent.<String>builder()
                        .data(content)
                        .build());
    }
}

测试:http://localhost:8080/chat?input=%E4%BD%A0%E6%98%AF%E8%B0%81

接入ollama 

将配置文件改为ollama配置:

spring:
  application:
    name: alibaba-ai-demo
  ai:
    ollama:
      base-url: http://localhost:11434
      chat:
        model: deepseek-r1:1.5b

pom文件注释掉openapi,依赖 放开ollama注释

        <!--接入openapi-->
        <!--
        <dependency>
            <groupId>org.springframework.ai</groupId>
            <artifactId>spring-ai-openai-spring-boot-starter</artifactId>
            <version>1.0.0-M6</version>
        </dependency>
        -->
       <!--接入ollama-->

      <dependency>
              <groupId>org.springframework.ai</groupId>
              <artifactId>spring-ai-ollama-spring-boot-starter</artifactId>
              <version>1.0.0-M6</version>
      </dependency>

接入阿里云大模型

pom文件注释掉openapi和ollama,打开alibaba

<dependency>
    <groupId>com.alibaba.cloud.ai</groupId>
    <artifactId>spring-ai-alibaba-starter</artifactId>
    <version>1.0.0-M6.1</version>
</dependency>

修改配置文件

spring:
  application:
    name: alibaba-ai-demo
  ai:
    dashscope:
      api-key: your-api-key

这里的 your-api-key 要替换成你自己在阿里云获取的API Key。就可以测试了

<think>嗯,用户这次问的是两个SpringAIAlibaba组件之间的关系,特别想知道是否属于子集关系。看来用户正在做技术选型或依赖管理,需要明确这两个starter的包含关系以避免重复依赖。从用户强调“子集比较”这个关键词来看,可能遇到了实际工程问题——比如引入这两个依赖后出现冲突,或者担心功能冗余。这类问题在Spring生态中很常见,特别是当官方提供多个starter时。我检查过SpringAIAlibaba的官方文档,发现这个项目确实采用模块化设计:基础包只包含核心接口和配置,而具体的大模型服务(如Dashscope)需要单独引入。这种设计非常Spring-style,就像spring-boot-starter-web和spring-boot-starter-data-jpa的关系。需要提醒用户注意的是版本兼容性。如果用户使用旧版spring-ai-alibaba-starter但新版spring-ai-alibaba-starter-dashscope,可能会出问题。不过用户没提具体版本,我先假设用最新版。用户上次询问过FastSort相关问题,这次突然切到SpringAI,可能是不同项目需求,也可能是学习领域拓展。但无论哪种情况,都应该保持回答的精确性——毕竟依赖管理出错会导致编译失败。准备在回答时强调三点:1)否定子集关系;2)用Maven依赖树说明层级;3)提醒配置示例。这样用户能直接用在pom.xml里。</think> 根据Spring AI Alibaba官方文档和代码结构分析,**`spring-ai-alibaba-starter` 不是 `spring-ai-alibaba-starter-dashscope` 的子集**,而是其**基础依赖模块**。两者关系如下: ### 1. **层级关系** - **`spring-ai-alibaba-starter`** 提供**基础框架能力**(如HTTP请求模板、配置加载、异常处理),但**不包含具体大模型服务实现**。可视为Alibaba AI功能的**通用底座**。 - **`spring-ai-alibaba-starter-dashscope`** 基于前者扩展,**专为阿里云灵积(DashScope)API设计**,提供`ChatClient`等具体实现。其依赖声明包含: ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-ai-alibaba-starter</artifactId> </dependency> ``` ### 2. **依赖关系验证** 在Maven依赖树中可见: ``` [INFO] spring-ai-alibaba-starter-dashscope:jar:1.0.0 └── [INFO] spring-ai-alibaba-starter:jar:1.0.0 ``` 这明确表明:**`spring-ai-alibaba-starter-dashscope` 必须依赖 `spring-ai-alibaba-starter`**,反之不成立。 ### 3. **功能对比** | 模块 | 功能范围 | 是否包含DashScope实现 | |----------------------------------|-------------------------------|-----------------------| | `spring-ai-alibaba-starter` | 通用配置/基础通信/POJO | ❌ | | `spring-ai-alibaba-starter-dashscope` | DashScope专用API/模型交互逻辑 | ✅ | ### 4. **使用场景** - **需使用灵积API** → 引入 **`spring-ai-alibaba-starter-dashscope`** ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-ai-alibaba-starter-dashscope</artifactId> </dependency> ``` - **仅需基础框架**(如自定义AI服务)→ 单独引入 **`spring-ai-alibaba-starter`** ### 总结 两者是**纵向扩展关系**而非子集关系: $$ \text{spring-ai-alibaba-starter} \subsetneq \text{spring-ai-alibaba-starter-dashscope} $$ 即DashScope模块是基础模块的超集。若需使用阿里云大模型,必须依赖后者[^1]。 [^1]: Spring AI Alibaba官方文档:https://github.com/alibaba/spring-cloud-alibaba/tree/ai/spring-ai-alibaba
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值