​​LangChain4j和LangGraph4j是合作还是竞品

​​LangChain4j和LangGraph4j是合作还是竞品

一、先搞清楚它们到底是谁

在开始对比之前,我们需要先明白一件事:LangChain4j 和 LangGraph4j 不是竞品,而是“能力接入层”和“流程编排层”的关系。

LangChain4j

它让 Java 应用“会说话”。

LangChain4j 是 LangChain 的 Java 移植版,本质上是一个Java LLM 应用开发框架,目的是让 Java 开发者能够方便地接入各种大语言模型和 AI 能力。

它提供了以下核心能力:

  • 统一的模型调用接口(支持 OpenAI、Google Vertex AI、Ollama、DeepSeek、通义千问等 20+ 模型)

  • Embeddings 和向量检索

  • RAG(检索增强生成)

  • Tool Calling(让模型能调用你的 Java 方法)

  • AiServices 高层 API(让你用声明式的方式定义 AI 服务)

打个比方,LangChain4j 就是你工具箱里的“AI 能力接入层”,负责解决“能不能用”的问题。

LangGraph4j

它让多个 AI 智能体“协作干活”。

LangGraph4j 是 LangGraph(Python 端)的 Java 移植版,是一个用于构建有状态、多智能体工作流的图式编排框架。

它的核心能力包括:

  • 有向状态图(StateGraph)编排

  • 条件分支和循环控制

  • 多智能体协作(Supervisor Pattern、Fan-out 等)

  • 检查点和断点恢复(Checkpointing)

  • 并行执行节点

  • Human-in-the-Loop(人工介入)

如果说 LangChain4j 是工具箱里的“零件”,那么 LangGraph4j 就是那张“搭积木的图纸和流水线”,负责解决“怎么编排更复杂”的问题。

从这张图可以看得很清楚:它们不是“谁替代谁”的关系,而是不同层级、相互配合的关系。

二、深入对比

2.1 LangChain4j—零件箱 + 接口适配层

LangChain4j 关注的核心问题是:“如何把大模型的能力接入 Java 应用。

它的设计哲学是模块化、低耦合、声明式

你可以把它的功能拆解成几个核心模块:

模块

能力

典型场景

ChatModel

统一对话模型接口,支持流式输出

聊天机器人、智能助手

EmbeddingModel

文本向量化,对接多种向量数据库

RAG 检索、相似度匹配

Tool Calling

将 Java 方法暴露给 LLM 调用

查询天气、查数据库、发邮件

AiServices

声明式定义 AI 服务,一行代码搞定

快速搭建 AI 应用原型

MCP

多链协同协议

多步复杂任务编排

LangChain4j 对 RAG 的支持尤其强大,内置了 30+ 种向量数据库的适配。

这意味着你不需要关心底层用的是什么向量库——PgVector、Milvus、Elasticsearch,通通都能接。

代码示例:用 AiServices 声明一个 AI 服务

// 第一步:定义一个接口,声明你要 AI 做什么 public interface Assistant { String chat(@UserMessage String message); } // 第二步:让 AiServices 帮你实现这个接口 Assistant assistant = AiServices.builder(Assistant.class) .chatLanguageModel(OpenAiChatModel.withApiKey("sk-xxx")) .build(); // 第三步:直接调用 String reply = assistant.chat("Java 中 ConcurrentHashMap 的工作原理是什么?"); System.out.println(reply);

看到没?

你只需要定义一个接口,AiServices 会自动帮你处理模型调用、消息构建、响应解析。

这就是 LangChain4j 的“声明式”力量——把 AI 服务当成普通 Java 接口来用。

2.2 LangGraph4j——流程引擎 + 状态机

LangGraph4j 关注的核心问题是:“如何把多个 AI 智能体的决策和行动流程化、状态化。

它的设计哲学是图即代码、状态即共享内存、节点即智能体行为。核心概念有三样:

① State(状态)——共享笔记本

LangGraph4j 强制所有智能体围绕一个共享的AgentState对象工作。这个 State 不是普通的 Map,而是具备类型安全、变更追踪、不可变快照能力的数据对象。

// 这就是你的共享笔记本!所有节点都靠它存数据、读数据、传数据 class MyState extends AgentState { String userQuestion; // 用户问什么 String weatherInfo; // 查到的天气结果 String aiAnswer; // AI 最终回答 List<String> toolCalls; // 需要调用的工具列表 }

State 的设计极大简化了多节点之间的数据传递——节点之间不直接说话,只读写这个笔记本,下游节点自然就能拿到上游节点的处理结果。

② StateGraph(状态图)——可执行的流程图

StateGraph 是 LangGraph4j 的核心抽象:你在纸上画流程图、写节点逻辑、画箭头,它帮你编译成“可运行程序”。

// 构建一个思考→行动→回答的三步 Agent 工作流 StateGraph<MyState> graph = new StateGraph<>(MyState.class) .addNode("think", this::thinkNode) // 思考节点:调用 LLM 分析意图 .addNode("act", this::actNode) // 行动节点:执行工具调用 .addNode("answer", this::answerNode) // 回答节点:生成最终答案 // 条件边:根据 State 决定下一步走哪条路 .addConditionalEdges("think", this::routeAfterThink) .addEdge("act", "answer") .addEdge("answer", END);
// 条件路由函数 —— 看一眼笔记本,决定下一步怎么走 private String routeAfterThink(MyState state) { if (state.toolCalls != null && !state.toolCalls.isEmpty()) { return "act"; // 有工具要调用 → 走行动节点 } return "answer"; // 没有 → 直接回答 }

这里的“条件边”是整个框架的灵魂。它不是静态配置,而是可以动态计算的路由逻辑——State 里有什么数据,决定下一步走哪个节点。

③ Checkpointing(检查点)——不怕系统崩溃

这是 LangGraph4j 在生产环境中最“救命”的特性。

每次 State 更新后,框架会自动序列化全量状态和执行上下文(包含 token 消耗、耗时、节点 ID、时间戳)到持久化存储。

一旦系统崩溃,你可以精准恢复到最后成功的检查点,重试失败的节点,而不是全链路重跑。

三、用一个例子看懂差异

3.1 用 LangChain4j做一个简单的智能体

做一个能调用工具的简单 Agent,LangChain4j 的代码非常简洁:

// 第一步:定义一个工具(Java 方法 + 注解) publicclass WeatherTool { @Tool("获取某个城市的当前天气") String getWeather(@P("城市名称") String city) { // 真实场景下这里会调用天气 API return city + "今天 25°C,晴朗"; } } // 第二步:构建 Agent ChatLanguageModel model = OpenAiChatModel.builder() .apiKey("sk-xxx") .build(); Agent agent = Agent.builder(model) .tools(new WeatherTool()) .build(); // 第三步:执行 String response = agent.execute("北京今天天气怎么样?"); System.out.println(response); // 输出:北京今天 25°C,晴朗

LangChain4j 的简洁就在于:一个@Tool注解 + 几行配置,模型就能自动识别“需要查天气”并调用你的 Java 方法。

3.2 用 LangGraph4j做一个带条件的多智能体

当场景变得复杂——比如需要先分析意图、再决定走哪个子流程、结果不满意还要重试——LangGraph4j 就派上用场了:

// 定义共享状态 class CodeReviewState extends AgentState { String prDescription; // PR 描述 String codeContent; // 代码内容 String reviewResult; // 审查结果 int reviewAttempts; // 重试次数 boolean needsImprovement; // 是否需要改进 } // 构建评审图 StateGraph<CodeReviewState> graph = new StateGraph<>(CodeReviewState.class) .addNode("analyze", this::analyzePr) // 分析 PR .addNode("review", this::reviewCode) // 审查代码 .addNode("improve", this::suggestFix) // 建议改进 .addNode("approve", this::approve) // 批准合并 .addConditionalEdges("review", state -> { if (state.reviewResult.contains("严重问题")) { return"improve"; // 有问题 → 改进 } return"approve"; // 没问题 → 批准 }) .addEdge("improve", "review") // 改进完重新审查(循环!) .build();

这个例子展示了 LangGraph4j 的核心优势:

  • 循环控制improve → review循环,问题没解决就一直修

  • 条件分支:根据 reviewResult 的内容动态决定下一步

  • 状态共享:所有节点共享CodeReviewState,reviewAttempts 用来控制重试次数

3.3 一句话总结差异

场景

用 LangChain4j

用 LangGraph4j

“给模型一个提示词,让它回答”

✅ 极简

❌ 过度设计

“一个智能体+几个工具”

✅ 刚刚好

⚠️ 稍重

“多步决策+条件分支”

⚠️ 需要手动管理状态

✅ 原生支持

“多智能体协作+长流程+断点恢复”

❌ 难以实现

✅ 设计目标

你可能也注意到了——LangChain4j 管的是“一次 AI 调用怎么优雅”,而 LangGraph4j 管的是“几十个智能体怎么协同走完整个业务流程”。它们是互补的,不是对立的。

四、LangGraph4j 的独特优势

如果说 LangChain4j 是“单兵作战”的利器,那 LangGraph4j 就是“多兵种协同”的总指挥部。

除了上面看到的分支和循环控制,LangGraph4j 还提供了几种极其强大的多智能体协作模式:

Supervisor Pattern(主控模式):一个主控 Agent 决定把任务分配给哪个专家 Agent 去执行。主控 Agent 分析用户意图,调用合适的 Worker Agent,并行处理子任务。

Fan-out(扇出模式):把同一个任务分发给多个子 Agent 并行处理,然后汇总所有结果。在做“多方观点分析”或“跨来源验证”时,这个模式非常有价值。

Human-in-the-Loop(人机协作):节点执行到敏感步骤时自动暂停,把状态推送给人工审批,等待人工响应后再继续后续流程。LangGraph4j 内置了对这种模式的原生支持。

Checkpointing + Time Travel:支持断点恢复和时间旅行式调试——你可以回溯到任何一个历史检查点,分析当时的 State,定位 LLM 幻觉或逻辑错误。

除了这些,LangGraph4j 还有更高级的能力:

  • 并行节点执行:多个独立任务可以并行运行,提升吞吐量。

  • 子图嵌套:可以把一个完整的 Graph 当作另一个 Graph 的节点,实现模块化复用。

  • 持久化检查点:支持 Redis、PostgreSQL 作为检查点存储后端,跨服务重启也能恢复。

  • 可视化工具:基于 Graphviz 生成可交互的 SVG 流程图。

五、优缺点全方位对比

LangChain4j 的优点

  • 功能全面、开箱即用:聊天气泡、向量检索、RAG、工具调用,你要的全都有。

  • 生态强大:天然支持 Spring Boot,可无缝集成现有 Java 中间件系统。

  • 声明式 API:AiServices 一行注解就能定义整个 AI 服务,把 AI 调用变成 Java 接口调用。

  • 低学习成本:API 设计直观,文档齐全,Java 开发者几乎零障碍上手。

  • 模型选择丰富:支持 OpenAI、Azure OpenAI、Google Vertex AI、Anthropic Claude、Ollama、DeepSeek、通义千问等 20+ 种模型。

LangChain4j 的局限性

  • Agent 编排能力有限:虽然支持基础的多步骤执行,但复杂工作流的编排和状态管理能力远不如 LangGraph4j。

  • 无内置状态管理:多轮对话和复杂上下文传递需要开发者自己维护状态。

  • 复杂文档处理受限:内置向量检索模块仅支持单级索引,对表格、图表等多模态文档的处理能力有限。

LangGraph4j 的优点

  • 状态图编排,表达能力极强:支持循环、条件分支、并行执行、子图嵌套,图灵完备的控制流。

  • 强大的多智能体协作能力:Supervisor 模式、Fan-out 扇出、Human-in-the-Loop 三大模式覆盖了 90% 的企业级多智能体场景。

  • 生产级可靠性保障:检查点机制 + 断点恢复,系统崩溃后不丢进度,对金融、政务等强一致性场景极其重要。

  • 框架无关,自由组合:LangGraph4j 提供了框架无关的核心抽象,可以与 LangChain4j 或 Spring AI 任意搭配使用。

LangGraph4j 的局限性

  • 不提供 AI 能力接入:它只负责“编排”,不负责“调用模型”。模型调用必须依赖 LangChain4j 或 Spring AI 来补充。

  • 学习曲线较陡:Graph、State、Node、Edge、Checkpoint 等概念很多,上手难度高于 LangChain4j。

  • 版本相对较新:目前稳定版本 1.7.10 / 1.8-beta,生态不如 LangChain4j 成熟。

六、2026 年最新版本状态

截至 2026 年上半年,两个框架都处于积极更新状态:

框架

最新版本

发布时间

主要更新

LangChain4j

1.11.0

2026-02-04

多模型支持增强、RAG 优化、MCP 模块完善

LangGraph4j

1.7.10 / 1.8-beta

2026-01

Hooks 机制、异步节点、并行执行优化、Checkpointing 增强

LangChain4j 的版本更新更偏向功能完善,LangGraph4j 则是逐步迈向稳定生产级别的路线。

七、一张表看清所有差异

对比维度

LangChain4j

LangGraph4j

核心定位

AI 能力接入层——“零件箱”

Agent 工作流编排层——“图纸”

核心抽象

ChatModel、AiServices、Tool

StateGraph、Node、Edge、Checkpoint

状态管理

无内置,需自行维护

强制 AgentState,类型安全、版本化、可回溯

条件路由

有限的 if-else 逻辑

条件边,支持复杂动态路由

循环支持

有限的递归

原生循环边,图灵完备

多智能体协作

基础的多实例调用

Supervisor + Worker + Fan-out + HITL

断点/检查点

内置,支持 Redis/PostgreSQL 持久化

并发执行

需要手动编排

原生并行节点、边

模型支持

20+ 种,统一接口

框架无关,依赖 LangChain4j 或 Spring AI

学习曲线

中等偏高

版本成熟度

高(1.11.0)

中(1.7.10)

Gradle/Maven集成

成熟

成熟

Spring Boot集成

原生支持

通过适配模块支持

可视化支持

一般

基于 Graphviz 生成可交互图谱

八、适用场景

纯用 LangChain4j 就够了

场景

典型应用

智能客服 / FAQ 问答系统

意图识别 + 知识库问答

RAG 知识库检索

文档问答、企业内部知识助手

单 Agent + 工具调用

订阅邮件发送、通知查询、简单 CRUD 任务

快速原型验证

一周内验证 AI 想法,概念验证

需要精细控制、低耦合的场景

已有复杂系统,只需小范围引入 AI 能力

对于这些场景,LangChain4j 开箱即用的能力 + 低学习成本是完全的优势。

需要 LangGraph4j 强力入场

场景

典型应用

复杂多轮决策 + 多智能体协作

代码 Review 多智能体系统、供应链智能调度

长流程审批 + 人机协作

项目审核系统、高危 SQL 审批、金融订单审核

需要断点恢复的长周期任务

舆情监测智能体(可能运行数小时甚至数天)

多个 Agent 并行执行 + 分阶段汇总

多方观点分析、跨来源信息验证

从 Python LangGraph 迁移

保持相同的图编排逻辑,技术栈换 Java

在这些场景中,LangGraph4j 提供的能力是 LangChain4j 单独使用时很难实现的。

最佳实践组合

最优雅的方案永远不是“二选一”。在实际项目里,LangChain4j + LangGraph4j是非常常见的组合方式:

  • LangChain4j 负责:模型调用、RAG 检索、Tool 定义、向量化存储

  • LangGraph4j 负责:状态图编排、多 Agent 协调、断点恢复、流程路由

LangGraph4j 官方路线也是这个思路:提供框架无关的核心抽象,通过适配模块分别适配 LangChain4j 和 Spring AI 的接口规范。

也就是说,不管你底层用 LangChain4j 还是 Spring AI,图编排的逻辑都是一样的,切换底层不需要改图。

九、快速上手

LangChain4j

  • GitHub:https://github.com/langchain4j/langchain4j

  • 官方文档:https://docs.langchain4j.dev

  • 最新版本:1.11.0(2026-02-04)

  • Maven 依赖

<dependency> <groupId>dev.langchain4j</groupId> <artifactId>langchain4j</artifactId> <version>1.11.0</version> </dependency>

LangGraph4j

  • GitHub:https://github.com/langgraph4j/langgraph4j

  • 最新版本:1.7.10 / 1.8-beta(2026-01)

  • Maven 依赖

<dependency> <groupId>org.bsc.langgraph4j</groupId> <artifactId>langgraph4j-core</artifactId> <version>1.7.10</version> </dependency> <!-- 与 LangChain4j 集成 --> <dependency> <groupId>org.bsc.langgraph4j</groupId> <artifactId>langgraph4j-langchain4j</artifactId> <version>1.7.10</version> </dependency>

十、写在最后

写到这里,我想用一句话做总结:LangChain4j 让你“能把大模型接入 Java”,LangGraph4j 让你“能优雅地把多个 AI 智能体编排起来”。

它们从来不是“二选一”的关系,而是不同层级的协作关系。

LangChain4j 是 AI 能力的接入层——给你模型 API、向量检索、Tool Calling;LangGraph4j 是流程编排层——给你状态图、条件路由、检查点恢复。

一个是“怎么接”,一个是“怎么排”。

技术选型的正确姿势不是问“哪个更好”,而是问自己三个问题:

  1. 我的业务需要几步决策?1-3 步,LangChain4j 足够;多步 + 分支 + 循环,LangGraph4j 入场。

  2. 我的 Agent 之间需要协作吗?单 Agent 用 LangChain4j;多 Agent 用 LangGraph4j 的 Supervisor 模式。

  3. 我的任务流程中,失败后能全部重跑吗?轻量任务没必要;长周期任务 + 断点恢复,LangGraph4j 的检查点机制几乎无可替代。

从轻到重的演进路径非常清晰:ChatModel 单次调用AiServices 声明式服务工具调用单 Agent多步骤条件链LangGraph4j 图编排