Pregel 实现了 LangGraph 的运行时,管理 LangGraph 应用程序的执行。
编译 StateGraph 或创建 entrypoint 会生成一个 Pregel 实例,该实例可以通过输入进行调用。
本指南从高层次解释了运行时,并提供了直接使用 Pregel 实现应用程序的说明。
注意: Pregel 运行时的名称源自 Google 的 Pregel 算法,该算法描述了一种使用图进行大规模并行计算的高效方法。
概览
在 LangGraph 中,Pregel 将 参与者 (actors) 和 通道 (channels) 结合到一个单一的应用程序中。参与者 从通道读取数据并向通道写入数据。Pregel 按照 Pregel 算法/批量同步并行 (Bulk Synchronous Parallel) 模型将应用程序的执行组织成多个步骤。 每个步骤由三个阶段组成:- 计划 (Plan):确定在此步骤中执行哪些 参与者。例如,在第一步中,选择订阅特殊 input 通道的 参与者;在随后的步骤中,选择订阅在上一步中更新的通道的 参与者。
- 执行 (Execution):并行执行所有选定的 参与者,直到全部完成,或有一个失败,或达到超时。在此阶段,通道更新对参与者是不可见的,直到下一步。
- 更新 (Update):使用本步骤中 参与者 写入的值更新通道。
参与者 (Actors)
参与者 是一个PregelNode。它订阅通道,从中读取数据,并向其写入数据。它可以被认为是 Pregel 算法中的一个 参与者。PregelNodes 实现了 LangChain 的 Runnable 接口。
通道 (Channels)
通道用于在参与者 (PregelNodes) 之间进行通信。每个通道都有一个值类型、一个更新类型和一个更新函数——该函数接受一系列更新并修改存储的值。通道可用于将数据从一个链发送到另一个链,或者在未来的步骤中将数据从一个链发送给它自己。LangGraph 提供了许多内置通道:LastValue:默认通道,存储发送到通道的最后一个值,对于输入和输出值或将数据从一个步骤发送到下一个步骤非常有用。Topic:可配置的 PubSub 主题,对于在 参与者 之间发送多个值或累积输出非常有用。可以配置为去重值或在多个步骤的过程中累积值。BinaryOperatorAggregate:存储持久值,通过将二元运算符应用于当前值和发送到通道的每个更新来更新,对于计算多个步骤的聚合非常有用;例如,total = BinaryOperatorAggregate(int, operator.add)
示例
虽然大多数用户将通过 StateGraph API 或 entrypoint 装饰器与 Pregel 交互,但也可以直接与 Pregel 交互。 以下是几个不同的示例,让您了解 Pregel API。- 单个节点
- 多个节点
- 主题 (Topic)
- BinaryOperatorAggregate
- 循环 (Cycle)
高级 API
LangGraph 提供了两个用于创建 Pregel 应用程序的高级 API:StateGraph (Graph API) 和 Functional API。- StateGraph (Graph API)
- Functional API
StateGraph (Graph API) 是一个更高级别的抽象,简化了 Pregel 应用程序的创建。它允许您定义节点和边的图。当您编译图时,StateGraph API 会自动为您创建 Pregel 应用程序。编译后的 Pregel 实例将与节点和通道列表相关联。您可以通过打印它们来检查节点和通道。您会看到类似这样的内容:您应该看到类似这样的内容:
将这些文档连接 到 Claude、VSCode 等,通过 MCP 获取实时解答。

