检查点。这些检查点会保存到一个线程中,可以在图执行后访问。由于线程允许在执行后访问图的状态,因此诸如人机协作、内存、时间旅行和容错等多种强大功能都成为可能。下面,我们将更详细地讨论这些概念。 
LangGraph API 自动处理检查点 使用 LangGraph API 时,您无需手动实现或配置检查点。API 在后台为您处理所有持久化基础设施。
线程
线程是分配给检查点保存的每个检查点的唯一 ID 或线程标识符。它包含一系列运行的累积状态。当执行运行后,助手的底层图的状态将持久化到线程中。 当使用检查点调用图时,您必须在配置的configurable部分指定一个thread_id。检查点
线程在特定时间点的状态称为检查点。检查点是每个超步骤保存的图状态的快照,由具有以下关键属性的StateSnapshot对象表示
config:与此检查点关联的配置。metadata:与此检查点关联的元数据。values:此时状态通道的值。next:图中要执行的下一个节点名称的元组。tasks:包含要执行的下一个任务信息的PregelTask对象元组。如果该步骤之前已尝试过,它将包含错误信息。如果图在节点内被动态中断,则任务将包含与中断相关的附加数据。
- 空检查点,将
START作为下一个要执行的节点 - 检查点,包含用户输入
{'foo': '', 'bar': []},将node_a作为下一个要执行的节点 - 检查点,包含
node_a的输出{'foo': 'a', 'bar': ['a']},将node_b作为下一个要执行的节点 - 检查点,包含
node_b的输出{'foo': 'b', 'bar': ['a', 'b']},没有下一个要执行的节点
bar通道有 reducer,因此bar通道值包含来自两个节点的输出。
获取状态
与保存的图状态交互时,您必须指定一个线程标识符。您可以通过调用graph.get_state(config)来查看图的最新状态。这将返回一个StateSnapshot对象,该对象对应于配置中提供的线程 ID 的最新检查点,或者如果提供,则对应于该线程的检查点 ID 的检查点。
get_state的输出将如下所示
获取状态历史
您可以通过调用graph.get_state_history(config)获取给定线程的图执行的完整历史记录。这将返回与配置中提供的线程 ID 关联的StateSnapshot对象列表。重要的是,检查点将按时间顺序排列,最近的检查点/StateSnapshot位于列表的首位。
get_state_history的输出将如下所示

重播
也可以回放之前的图执行。如果我们使用`thread_id`和`checkpoint_id`调用一个图,那么我们将重放与`checkpoint_id`对应的检查点之前已执行的步骤,并且只执行检查点之后的步骤。thread_id是线程的 ID。checkpoint_id是引用线程中特定检查点的标识符。
configurable部分的一部分传递。
checkpoint_id之前的步骤。checkpoint_id之后的所有步骤都将被执行(即新的分支),即使它们以前执行过。请参阅此关于时间旅行的指南,了解有关重播的更多信息。 
更新状态
除了从特定的检查点重放图之外,我们还可以编辑图状态。我们使用update_state来完成此操作。此方法接受三个不同的参数
配置
配置应包含thread_id,指定要更新哪个线程。当只传递thread_id时,我们更新(或分叉)当前状态。可选地,如果包含checkpoint_id字段,则分叉该选定的检查点。
值
这些值将用于更新状态。请注意,此更新的处理方式与来自节点的任何更新完全相同。这意味着这些值将传递给reducer函数(如果它们定义了图中某些通道的 reducer)。这意味着update_state不会自动覆盖每个通道的通道值,而只会覆盖没有 reducer 的通道。让我们看一个例子。 假设您已经使用以下 schema 定义了图的状态(请参阅上面的完整示例):作为节点
调用update_state时,您可以选择指定的最后一件事是as_node。如果您提供了它,更新将像来自节点as_node一样应用。如果未提供as_node,它将被设置为最后更新状态的节点(如果不模糊)。这很重要,因为要执行的下一步取决于最后一个进行更新的节点,因此这可用于控制下一个执行的节点。请参阅此关于时间旅行的指南,了解有关分叉状态的更多信息。 
内存存储

Store接口的需求。为了说明这一点,我们可以定义一个InMemoryStore来存储关于用户在不同线程之间的信息。我们只需像以前一样,使用检查点和我们的新in_memory_store变量编译我们的图。LangGraph API 自动处理存储 使用 LangGraph API 时,您无需手动实现或配置存储。API 在后台为您处理所有存储基础设施。
基本用法
首先,让我们在不使用 LangGraph 的情况下单独展示这一点。store.put方法将内存保存到存储中的命名空间。执行此操作时,我们指定命名空间(如上定义)以及内存的键值对:键只是内存的唯一标识符(memory_id),值(字典)是内存本身。
Item)。我们可以像上面那样通过.dict将其转换为字典来访问它。 它具有的属性是:value:此记忆的值(本身是一个字典)key:此记忆在此命名空间中的唯一键namespace:一个字符串列表,此记忆类型的命名空间created_at:此记忆创建的时间戳updated_at:此记忆更新的时间戳
语义搜索
除了简单的检索,该存储还支持语义搜索,允许您根据含义而不是精确匹配来查找记忆。要启用此功能,请使用嵌入模型配置存储在 LangGraph 中使用
一切就绪后,我们在 LangGraph 中使用in_memory_store。in_memory_store与检查点器协同工作:检查点器将状态保存到线程中,如上所述,而in_memory_store允许我们存储任意信息以供跨线程访问。我们如下所示编译图,同时使用检查点器和in_memory_store。
store: BaseStore和config: RunnableConfig作为节点参数传递,在任何节点中访问in_memory_store和user_id。以下是我们可能在节点中使用语义搜索来查找相关记忆的方法
store.search方法获取记忆。回想一下,记忆以对象列表的形式返回,可以转换为字典。
langgraph.json文件中配置索引设置。例如
检查点库
在幕后,检查点功能由符合BaseCheckpointSaver接口的检查点对象提供。LangGraph 提供了多种检查点实现,所有这些都通过独立的、可安装的库实现
langgraph-checkpoint:检查点保存器(BaseCheckpointSaver)和序列化/反序列化接口(SerializerProtocol)的基本接口。包括用于实验的内存中检查点实现(InMemorySaver)。LangGraph 包含langgraph-checkpoint。langgraph-checkpoint-sqlite:使用 SQLite 数据库实现 LangGraph 检查点(SqliteSaver/AsyncSqliteSaver)。适用于实验和本地工作流。需要单独安装。langgraph-checkpoint-postgres:使用 Postgres 数据库(PostgresSaver/AsyncPostgresSaver)的高级检查点,用于 LangSmith。适用于生产环境。需要单独安装。
检查点接口
每个检查点都符合BaseCheckpointSaver接口并实现了以下方法
.put- 存储带配置和元数据的检查点。.put_writes- 存储与检查点关联的中间写入(即待定写入)。.get_tuple- 使用给定配置(thread_id和checkpoint_id)获取检查点元组。这用于在graph.get_state()中填充StateSnapshot。.list- 列出符合给定配置和过滤条件的检查点。这用于在graph.get_state_history()中填充状态历史。
.ainvoke、.astream、.abatch执行图),则将使用上述方法的异步版本(.aput、.aput_writes、.aget_tuple、.alist)。
为了异步运行您的图,您可以使用
InMemorySaver,或者 SQLite/Postgres 检查点器的异步版本 — AsyncSqliteSaver / AsyncPostgresSaver 检查点器。序列化器
当检查点保存图状态时,它们需要序列化状态中的通道值。这是通过序列化器对象完成的。langgraph_checkpoint定义了实现序列化器的协议,并提供了默认实现(JsonPlusSerializer),该实现处理各种类型,包括 LangChain 和 LangGraph 原语、日期时间、枚举等。使用pickle进行序列化
默认的序列化器JsonPlusSerializer在底层使用 ormsgpack 和 JSON,这不适用于所有类型的对象。 如果您想对我们当前的 msgpack 编码器不支持的对象(例如 Pandas 数据帧)回退到 pickle,您可以使用JsonPlusSerializer的pickle_fallback参数:加密
检查点器可以选择加密所有持久化状态。要启用此功能,请将EncryptedSerializer的实例传递给任何BaseCheckpointSaver实现的serde参数。创建加密序列化器最简单的方法是通过from_pycryptodome_aes,它从LANGGRAPH_AES_KEY环境变量读取 AES 密钥(或接受key参数)。
LANGGRAPH_AES_KEY存在,加密就会自动启用,因此您只需提供环境变量即可。可以通过实现CipherProtocol并将其提供给EncryptedSerializer来使用其他加密方案。
能力
人工干预
首先,检查点通过允许人类检查、中断和批准图步骤来促进人机协作工作流。这些工作流需要检查点,因为人类必须能够随时查看图的状态,并且图在人类对状态进行任何更新后必须能够恢复执行。有关示例,请参阅操作指南。内存
其次,检查点允许在交互之间拥有“记忆”。在重复的人机交互(如对话)的情况下,任何后续消息都可以发送到该线程,该线程将保留其对以前消息的记忆。请参阅添加记忆以了解如何使用检查点添加和管理对话记忆。时间旅行
第三,检查点允许“时间旅行”,允许用户重放先前的图执行,以审查和/或调试特定的图步骤。此外,检查点使得在任意检查点分叉图状态以探索替代轨迹成为可能。容错
最后,检查点还提供容错和错误恢复功能:如果一个或多个节点在给定超步骤失败,您可以从上次成功步骤重新启动图。此外,当图节点在给定超步骤执行中途失败时,LangGraph 会存储该超步骤中任何其他成功完成的节点的待定检查点写入,以便在从该超步骤恢复图执行时,我们不会重新运行成功的节点。待定写入
此外,当图节点在给定超步骤执行中途失败时,LangGraph 会存储该超步骤中任何其他成功完成的节点的待定检查点写入,以便在从该超步骤恢复图执行时,我们不会重新运行成功的节点。以编程方式连接这些文档到 Claude、VSCode 等,通过 MCP 获取实时答案。