LangChain4j入门使用

1. 概述

1.1. 简述

LangChain4J ​ 是 Java 生态中对接 ​LangChain​ 核心能力的现代化开发库,专注于简化 Java 应用与大语言模型(LLM)及智能代理(Agents)、工具(Tools)、文档检索(RAG)等功能的集成。基础知识这里不赘述,可以网上自行查看。

1.2. 本节目标

初步使用LangChain4j调用接口,能与模型进行简单的对话。官方文档中LangChain4j的接口有low-levelhigh-level 之分,其实high-level 就是基于low-level上做了一些封装,本节按照low-level的接口先将代码跑通。

2. 环境准备

2.1. 版本要求

  • Java:JDK17或更高的版本
  • 包管理工具:Maven
  • 阿里云百炼上申请模型的试用,获取apiKey,也可以试用本地部署的ollama进行调用,快速了解的话建议还是使用线上的模型

2.2. Maven依赖

如果需要开日志,还需要引入日志模块,下面提供的是基础模块,根据需要引入一个就好了。

xml 复制代码
<!--使用OpenAi的这个包,这个包只要模型提供跟OpenAi类似的接口,就可以调用,并非针对OpenAi的模型-->
<dependency>
    <groupId>dev.langchain4j</groupId>
    <artifactId>langchain4j-open-ai</artifactId>
    <version>1.6.0</version>
</dependency>

<!-- 对接 Ollama 的模块(本地模型) -->
<dependency>
    <groupId>dev.langchain4j</groupId>
    <artifactId>langchain4j-ollama</artifactId>
    <version>1.6.0</version>
</dependency>

3. 快速入门

3.1. 调用阿里千问的大语言模型

java 复制代码
package com.ketech;

import dev.langchain4j.model.openai.OpenAiChatModel;

/**
 * Hello world!
 *
 */
public class App 
{
    public static void main( String[] args )
    {
        # 阿里百炼平台申请的apiKey,请填入自己申请的
        String apiKey = "sk-XXXXXXXXXXXX";
        OpenAiChatModel chatModel = OpenAiChatModel.builder()
                                            .baseUrl("https://dashscope.aliyuncs.com/compatible-mode/v1")
                                            .apiKey(apiKey)
                                            .modelName("qwen-max")
                                            .logRequests(true)
                                            .logResponses(true)
                                            .build();
        String result = chatModel.chat("你好,你是谁?");
        System.out.println( result );
    }
}

说明:

  • apiKey:百炼平台申请的key
  • modelName:百炼平台上的模型名称,百炼上提供了很多的模型供调用,根据自己的需要选择一个
  • basuUrl:基础的Url,可以点进需要调用的模型,说明中提供了baseUrl的地址
  • logRequest:开启请求日志,开启后控制台可打印出具体信息,方便查看
  • logResponse:开启访问日志,开启后控制台可打印出具体信息,方便查看
  • 还有其他很多的配置项,本节只做简单的入门,后续有时间可继续探讨

阿里千问查看baseUrl示例

控制台打印的结果信息

3.2. 调用本地的ollama部署的大语言模型

没有实际测试过,后面测一下,注意引入的依赖。

java 复制代码
package com.ketech;

import dev.langchain4j.model.openai.OpenAiChatModel;

/**
 * Hello world!
 *
 */
public class App 
{
    public static void main( String[] args )
    {
        OpenAiChatModel chatModel = OpenAiChatModel.builder()
                                            .baseUrl("http://localhost:11434")
                                            .modelName("qwen-max")
                                            .logRequests(true)
                                            .logResponses(true)
                                            .build();
        String result = chatModel.chat("你好,你是谁?");
        System.out.println( result );
    }
}
相关推荐
吴佳浩8 小时前
Python入门指南(六) - 搭建你的第一个YOLO检测API
人工智能·后端·python
踏浪无痕8 小时前
JobFlow已开源:面向业务中台的轻量级分布式调度引擎 — 支持动态分片与延时队列
后端·架构·开源
Pitayafruit8 小时前
Spring AI 进阶之路05:集成 MCP 协议实现工具调用
spring boot·后端·llm
ss2739 小时前
线程池:任务队列、工作线程与生命周期管理
java·后端
不像程序员的程序媛9 小时前
Spring的cacheEvict
java·后端·spring
踏浪无痕9 小时前
JobFlow 实战:无锁调度是怎么做到的
后端·面试·架构
shoubepatien10 小时前
JAVA -- 11
java·后端·intellij-idea
喵个咪10 小时前
开箱即用的 GoWind Admin|风行,企业级前后端一体中后台框架:kratos-bootstrap 入门教程(类比 Spring Boot)
后端·微服务·go
uzong10 小时前
从大厂毕业后,到小公司当管理,十年互联网老兵的思维习惯阶段复盘
后端
追逐时光者10 小时前
一个 WPF 开源、免费的 SVG 图像查看控件
后端·.net