AI框架—LangChain4j系列 :LangChain4j -Spring Boot集成

一、Spring Boot starter 通用集成

1、引入依赖

Spring Boot starters通过属性帮助创建和配置语言模型、嵌入模型、嵌入存储和其他核心LangChain4j组件。

要使用Spring Boot starters,请导入相应的依赖关系。

Spring Boot启动器依赖项的命名约定是:langchain4j-{integration-name}-spring-boot-starter.

例如,对于OpenAI(langchain4j open-ai),依赖项名称将是langchain4j open ai spring bootstarter:

复制代码
<dependency>
    <groupId>dev.langchain4j</groupId>
    <artifactId>langchain4j-open-ai-spring-boot-starter</artifactId>
    <version>0.35.0</version>
</dependency>

2、参数配置

然后,您可以在application.properties文件中配置模型参数,如下所示:

复制代码
langchain4j.open-ai.chat-model.api-key=${OPENAI_API_KEY}
langchain4j.open-ai.chat-model.model-name=gpt-4o
langchain4j.open-ai.chat-model.log-requests=true
langchain4j.open-ai.chat-model.log-responses=true
...

在这种情况下,将自动创建OpenAiChatModel的实例(ChatLanguageModel的实现),您可以在需要时自动连接它:

复制代码
@RestController
public class ChatController {

    ChatLanguageModel chatLanguageModel;

    public ChatController(ChatLanguageModel chatLanguageModel) {
        this.chatLanguageModel = chatLanguageModel;
    }

    @GetMapping("/chat")
    public String model(@RequestParam(value = "message", defaultValue = "Hello") String message) {
        return chatLanguageModel.generate(message);
    }
}

如果您需要StreamingChatLanguageModel的实例,请使用流式聊天模型而不是聊天模型属性:

复制代码
langchain4j.open-ai.streaming-chat-model.api-key=${OPENAI_API_KEY}
...

二、Spring Boot starter声明式AI服务的集成

LangChain4j提供了一个Spring Boot starters,用于自动配置AI服务、RAG、工具等。

假设您已经导入了一个集成启动器(见上文),请导入langchain4j spring boot starter:

复制代码
<dependency>
    <groupId>dev.langchain4j</groupId>
    <artifactId>langchain4j-spring-boot-starter</artifactId>
    <version>0.35.0</version>
</dependency>

现在,您可以定义AI服务接口并用@AiService对其进行注释:

复制代码
@AiService
interface Assistant {

    @SystemMessage("You are a polite assistant")
    String chat(String userMessage);
}

将其视为标准的Spring Boot@Service,但具有AI功能。

当应用程序启动时,LangChain4j starter将扫描类路径并找到所有用@AiService注释的接口。对于找到的每个AI服务,它将使用应用程序上下文中可用的所有LangChain4j组件创建此接口的实现,并将其注册为bean,以便您可以在需要时自动连接它:

复制代码
@RestController
class AssistantController {

    @Autowired
    Assistant assistant;

    @GetMapping("/chat")
    public String chat(String message) {
        return assistant.chat(message);
    }
}

1、组件自动装配

如果要在application context中可用,则以下组件将自动连接到AI服务:

  • ChatLanguageModel
  • StreamingChatLanguageModel
  • ChatMemory
  • ChatMemoryProvider
  • ContentRetriever
  • RetrievalAugmentor

所有用@Tool注释的方法(注意,这些方法必须在SpringBean类中定义)

2、显示组件装配

如果您有多个AI服务,并且希望将不同的LangChain4j组件连接到每个服务中,则可以指定要与显式连接模式一起使用的组件(@AiService(wiringMode=explicit))。

假设我们配置了两个ChatLanguageModel:

复制代码
# OpenAI
langchain4j.open-ai.chat-model.api-key=${OPENAI_API_KEY}
langchain4j.open-ai.chat-model.model-name=gpt-4o-mini

# Ollama
langchain4j.ollama.chat-model.base-url=http://localhost:11434
langchain4j.ollama.chat-model.model-name=llama3.1

@AiService(wiringMode = EXPLICIT, chatModel = "openAiChatModel")
interface OpenAiAssistant {

    @SystemMessage("You are a polite assistant")
    String chat(String userMessage);
}

@AiService(wiringMode = EXPLICIT, chatModel = "ollamaChatModel")
interface OllamaAssistant {

    @SystemMessage("You are a polite assistant")
    String chat(String userMessage);
}
相关推荐
morris1311 小时前
【redis】redis实现分布式锁
数据库·redis·缓存·分布式锁
hycccccch2 小时前
Canal+RabbitMQ实现MySQL数据增量同步
java·数据库·后端·rabbitmq
这个懒人2 小时前
深入解析Translog机制:Elasticsearch的数据守护者
数据库·elasticsearch·nosql·translog
Yan-英杰2 小时前
【百日精通JAVA | SQL篇 | 第二篇】数据库操作
服务器·数据库·sql
用键盘当武器的秋刀鱼3 小时前
springBoot统一响应类型3.5.1版本
java·spring boot·后端
NineData3 小时前
NineData云原生智能数据管理平台新功能发布|2025年3月版
数据库
小李同学_LHY4 小时前
三.微服务架构中的精妙设计:服务注册/服务发现-Eureka
java·spring boot·spring·springcloud
百代繁华一朝都-绮罗生4 小时前
检查是否存在占用内存过大的SQL
数据库·sql
吾日三省吾码4 小时前
Python 脚本:自动化你的日常任务
数据库·python·自动化
CZIDC4 小时前
win11 系统环境下 新安装 WSL ubuntu + ssh + gnome 桌面环境
数据库·ubuntu·ssh