cadence-workflow - Uber Cadence 中的子工作流程有什么好的用例?
问题描述
我正在尝试使用 Uber Cadence 了解子工作流程的用例。与简单地将工作流程拆分为函数相比,子工作流程的优势是什么?我有一个相当复杂的工作流程,我正在考虑将其拆分为多个子工作流程,但我不确定这样做的利弊。
解决方案
- 子工作流可以由不包含父工作流代码的单独一组工作人员托管。因此,它将充当一个单独的服务,可以从多个其他工作流中调用。
- 单个工作流的大小有限。例如,它不能执行 100k 活动。子工作流可用于将问题划分为更小的块。一个父母有 1000 个孩子,每个孩子执行 1000 项活动,就会执行 100 万项活动。
- 子工作流可用于使用其 ID 管理某些资源以保证唯一性。例如,管理主机升级的工作流可以有每个主机的子工作流(主机名是工作流 ID),并使用它们来确保主机上的所有操作都是序列化的。
- 子工作流可用于执行一些周期性逻辑,而不会破坏父历史大小。父级启动一个子级,该子级执行周期性逻辑调用 continue as new 根据需要多次,然后完成。从父级的角度来看,它只是一个子工作流调用。
子工作流与将所有应用程序逻辑并置在单个工作流中的主要限制是缺乏共享状态。父子只能通过异步信号进行通信。但是,如果它们之间存在紧密耦合,则使用单个工作流并仅依赖共享对象状态可能会更简单。
如果您的问题在执行活动的数量和处理的信号方面具有一定的规模,我个人建议从单个工作流实现开始。它只是比多个异步通信工作流更简单。
此外,人们经常注意到工作流不仅仅是函数,您可以在其中使用 OO 的全部功能。使用结构、接口和其他 OO 技术将逻辑分解为更易于管理的抽象。
推荐阅读
- python - 如何在 html 页面上显示 tqdm 进度?
- google-chrome-extension - 向 Chrome OAuth 身份屏幕添加图标?
- sql - 当我尝试在 IBM Db2 云上加载数据时,弹出一个无效的身份验证或令牌过期,有人知道如何解决这个问题吗?
- azure - 如何创建使用二头肌而不是 JSON 模板的“部署到 Azure”按钮?
- javascript - 计时器计数太快
- typescript - 类型推断、柯里化和泛型未返回预期类型
- python - Selenium 键盘。仅将键发送到特定窗口
- aws-lambda - aws xgboost - lambda 函数
- wordpress - WP_Query 或 get_posts() 崩溃函数
- python - 如何解决处理矩阵并将值与第二个矩阵组合的问题?