【Agent笔记 | 第五篇】LangChain&LangGraph

目录

[LangChain 详解](#LangChain 详解)

[1. 定义与定位](#1. 定义与定位)

[2. 核心功能](#2. 核心功能)

[3. 主要用途](#3. 主要用途)

[LangGraph 详解](#LangGraph 详解)

[1. 定义与定位](#1. 定义与定位)

[2. 核心特性](#2. 核心特性)

[3. 主要用途](#3. 主要用途)

[LangChain vs LangGraph 核心区别](#LangChain vs LangGraph 核心区别)


LangChain 详解

1. 定义与定位

LangChain 是一个用于构建基于大语言模型(LLM)应用程序的开源框架。它主要定位为工具包(Toolkit),为开发者提供了一系列可组合的组件和工具,用于将LLM与外部数据源、工具和服务连接起来。

2. 核心功能

组件化设计:LangChain采用模块化架构,包含以下核心组件:

  • Models(模型):支持各种LLM提供商的接口封装
  • Prompts(提示模板):管理和优化提示工程
  • Chains(链):将多个组件串联成工作流
  • Memory(记忆):管理对话上下文和状态
  • Indexes(索引):文档加载、分割和向量存储
  • Agents(代理):基于LLM的决策和工具调用

集成生态:LangChain提供了丰富的集成,支持:

  • 各种LLM提供商(OpenAI、Anthropic、Cohere等)
  • 向量数据库(Pinecone、Weaviate、Chroma等)
  • 工具和API(搜索引擎、计算器、代码执行器等)

3. 主要用途

  1. 文档问答系统:基于检索增强生成(RAG)的问答
  2. 聊天机器人:具有上下文记忆的对话系统
  3. 内容生成:自动化写作和摘要生成
  4. 数据分析:将自然语言转换为数据库查询
  5. 代码生成与执行:AI辅助编程

LangGraph 详解

1. 定义与定位

LangGraph 是LangChain团队开发的图结构编排框架 ,专门用于构建有状态的、多参与者(multi-actor)的应用程序。它主要定位为编排框架(Orchestration Framework),专注于解决复杂agent工作流的编排问题。

2. 核心特性

图结构工作流 :LangGraph基于有向图的概念,允许开发者定义:

  • 节点(Nodes):代表计算单元或函数
  • 边(Edges):定义执行流程和条件分支
  • 状态(State):在节点间传递和维护的共享数据

关键优势

  • 支持循环:与传统的DAG(有向无环图)不同,LangGraph支持循环和条件分支
  • 状态管理:内置的状态持久化和恢复机制
  • 人类干预:支持在执行过程中插入人工审核步骤
  • 流式处理:支持实时流式输出和中间结果

3. 主要用途

  1. 复杂Agent系统:多步骤、多工具协调的智能体
  2. 对话流程管理:复杂的多轮对话状态机
  3. 自动化工作流:业务流程自动化和决策树
  4. 人机协作系统:需要人工审核和干预的任务
  5. 实时交互应用:需要流式响应的系统

LangChain vs LangGraph 核心区别

维度 LangChain LangGraph
定位 工具包(Toolkit) 编排框架(Orchestration Framework)
架构 链式组合(Chain-based) 图结构(Graph-based)
状态管理 基础对话记忆 内置状态持久化和恢复
执行模式 线性流水线 支持循环和条件分支
复杂度 适合简单到中等复杂度任务 适合复杂多步骤工作流
人类干预 需要额外实现 内置支持
学习曲线 相对平缓 相对陡峭

实际上,LangChain和LangGraph经常协同工作

  • 使用LangChain的组件作为构建块(模型、工具、检索器等)
  • 使用LangGraph作为编排层来组织这些构建块

例如,你可以用LangChain连接向量数据库和LLM,然后用LangGraph来编排一个复杂的RAG agent,该agent能够:

  1. 分析用户查询
  2. 决定是否需要检索
  3. 执行多轮检索和推理
  4. 在需要时请求人工澄清
相关推荐
.千余1 小时前
【Linux】 TCP进阶详解:字节流、粘包问题、异常情况与UDP完整对比2
linux·运维·c语言·开发语言·经验分享·笔记·php
Upsy-Daisy1 小时前
IOTA 学习笔记(二):DAG 与 Tangle 到底是什么?
笔记·学习
不羁的木木1 小时前
Form Kit(卡片开发服务)学习笔记05-进阶实战与性能优化
笔记·学习·harmonyos
abigale031 小时前
LangChain 多轮对话记忆:基于 session_id 实现多会话隔离
typescript·langchain·uuid·session_id
土狗TuGou1 小时前
SQL内功笔记 · 第7篇:CTE&临时表&递归
数据库·笔记·后端·sql·mysql
05候补工程师2 小时前
【英语学习笔记】基于“底层逻辑转换”与“去动词化”的英汉互译核心方法论及写作高分公式
经验分享·笔记·学习·考研
大明者省2 小时前
CentOS 与 Ubuntu Python 部署差异
笔记·python·ubuntu·centos
bbaydnog2 小时前
FreeRTOS学习笔记 17:资源管理与临界区保护——优先级反转、死锁,90%的RTOS bug都跟它有关
笔记·学习·bug
fanged2 小时前
Datasheet学习5(STM32)(TODO)
笔记