理解langchain langgraph 官方文档示例代码中的MemorySaver

以下是langchain v0.3官方示例代码

python 复制代码
from langgraph.checkpoint.memory import MemorySaver
from langgraph.graph import START, MessagesState, StateGraph

# 可以理解为:定义一个流程,这个流程中用到的数据类型是Messages。 <---定义一个有向图,指定状态模式/格式/规范为 MessagesState这种规范
workflow = StateGraph(state_schema=MessagesState)


# 定义调用模型的函数
def call_model(state: MessagesState):
    response = model.invoke(state["messages"])
    return {"messages": response}


# 整个流程只有一个节点,可谓是最简单的任务流了
workflow.add_edge(START, "model")
workflow.add_node("model", call_model)

# 把"记忆保存器"这个中间件注入到流程中
memory = MemorySaver()
app = workflow.compile(checkpointer=memory)

config = {"configurable": {"thread_id": "abc123"}}

query = "Hi! I'm Bob."

input_messages = [HumanMessage(query)]
output = app.invoke({"messages": input_messages}, config)
output["messages"][-1].pretty_print()  # output contains all messages in state

query = "What's my name?"

input_messages = [HumanMessage(query)]
output = app.invoke({"messages": input_messages}, config)
output["messages"][-1].pretty_print()

输出

python 复制代码
==================================[1m Ai Message [0m==================================

Hi Bob! How can I assist you today?


==================================[1m Ai Message [0m==================================

Your name is Bob! How can I help you today, Bob?

这里涉及到图论的基础知识,要快速了最基础概念,推荐这个视频:【硬核干货】图论到底是个什么玩意儿?图论入门:树与生成树 (Graph Theory: Tree and Spanning Tree)_哔哩哔哩_bilibili

图 (Graph):基于图论的概念,它由节点 (nodes) 和边 (edges) 组成。

节点 (Nodes): 节点是工作流中的执行单元,每个节点都关联一个函数,该函数定义了节点的执行逻辑。

边 (Edges): 边定义了节点之间的连接关系,以及工作流的执行路径。

状态 (State):标记节点及节点的状态,定义节点之间的连接和流向。--> 简单直观地理解的话,可以把State理解为我们常规编程中常用的Data

StateGraph= State + Graph --> 依据【状态】来运作的【有向图】--->可近似理解为工作流

python 复制代码
workflow = StateGraph(state_schema=MessagesState)

当中,state_schema 参数定义了这个"状态驱动的有向图" 的状态描述格式/标准/规范 采用 MessagesState 这种数据结构的规范。

--> 更通俗理解的话,可以把它想象成是以下语句在LangGraph场景下的固有写法:

复制代码
# 以下这是一段伪代码
workflow = LangChainWorkFlow(data_type=Messages) 

------ MemorySaver ------

python 复制代码
memory = MemorySaver()
app = workflow.compile(checkpointer=memory)

这里的MemorySaver有点像一个中间件,你可以把它当作中间件来理解。

中间件有什么特征:它在程序执行过程中某些数据流的环节介入,并根据设定的逻辑对部分数据进行加工或调整数据的流向,而这一切对用户来说是透明的,看不见的,像一只看不见的手在那里做了些什么。

  • 它不是核心逻辑 ,但能在数据流经过时 插入 自己的逻辑。
  • 它不改变程序的主要流程 ,但能 修改、过滤、检查 数据。
  • 它对用户是透明的 ,但对系统来说是 必不可少的

中间件在程序中的作用

作用 示例
数据过滤 日志记录、请求验证、权限检查
数据转换 格式转换、加密/解密、压缩
流向控制 负载均衡、路由选择、错误处理

MemorySaver 在这里中的作用类似于一个"中间件",workflow编译的时候提供了一个"检查点(checkpointer)"让这个中间件介入进去,让这个看不见的手去捕获并加工里面数据。

这个参数名叫checkpointer我觉得名字起得非常好。

相关推荐
都叫我大帅哥1 分钟前
Java DelayQueue:时间管理大师的终极武器
java
秋千码途8 分钟前
小架构step系列27:Hibernate提供的validator
java·spring·架构·hibernate
都叫我大帅哥9 分钟前
TOGAF迁移规划阶段全解密:从菜鸟到达人的通关秘籍
java
探索java11 分钟前
深入理解 Spring 中的 XmlBeanFactory 原理及实践
java·spring·xmlbeanfactory
JosieBook1 小时前
【web应用】如何进行前后端调试Debug? + 前端JavaScript调试Debug?
前端·chrome·debug
LBJ辉1 小时前
2. Webpack 高级配置
前端·javascript·webpack
hqxstudying2 小时前
Java异常处理
java·开发语言·安全·异常
我命由我123455 小时前
Kotlin 数据容器 - List(List 概述、创建 List、List 核心特性、List 元素访问、List 遍历)
java·开发语言·jvm·windows·java-ee·kotlin·list
武子康7 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
灵感__idea8 小时前
JavaScript高级程序设计(第5版):好的编程就是掌控感
前端·javascript·程序员