【Temporal】方法规范

embedded/2024/11/15 3:25:51/

在workflow或者childWorkflow的方法代码中,不能使用golang的一些库方法,比如sleep,go协程等,必须使用其对应的封装方法,比如对应关系如下:

  • time.Sleep -> workflow.Sleep

  • go xx -> workflow.Go(xx)

这是因为workflow或者childWorkflow代码是在workflow的线程或者协程中调度的,任务的控制不能交给golang处理。

而对于activity的方法代码中,就应该使用golang的库方法,而不是workflow的封装方法。

换句话说:

  • workflow或者childWorkflow方法代码应该只包含编排/管理其他工作流实体(如activity/childWF/channel/等)的逻辑;

  • activity方法代码才是具体的业务逻辑。

这也是temporal提倡的代码规范

从workflow和activity的方法定义我们也可以知道:
对于activity来说,方法定义的第一个参数必须是golang 的context:

func StartCteTaskActivity(ctx context.Context, xx, xx) (xx, error)

对于workflow来说,方法定义的第一个参数必须是workflow 的context

func RunTimeNodeMonitorWorkflow(wfCtx workflow.Context, xx, xx) (xx, error)

https://community.temporal.io/t/workflow-sleep-details/1161


http://www.ppmy.cn/embedded/115050.html

相关文章

Redis——redispluspls库list及set类型相关接口使用

文章目录 list 类型相关接口lpush和lrangerpushlpop和rpopblpop和brpopllen set 类型相关接口sadd和smemberssismemberscardspopsinstersinterstore list 类型相关接口 lpush和lrange void lrange_lpush(sw::redis::Redis& redis){std::cout<<"lpush 和 lrang…

Elasticsearch如何排序,分页以及高亮查询

目录 一、排序 二、分页查询 三、高亮查询 一、排序 ES中默认使用相关度分数实现排序&#xff0c;可以通过搜索语法定制化排序。 GET /索引/_search { "query": 搜索条件,"sort": [{"字段1":{"order":"asc"} },{ "字…

mysql学习教程,从入门到精通,SQL 删除表(DROP TABLE 语句)(21)

1、SQL 联表查询(Join) 在编写SQL联表查询&#xff08;Join&#xff09;时&#xff0c;我们首先要明确查询的目的&#xff0c;即我们需要从哪些表中提取数据&#xff0c;以及这些表之间如何关联。以下是一个简单的示例&#xff0c;假设我们有两个表&#xff1a;employees&…

极狐GitLab CI/CD 功能合集(超详细教程)

极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门面向中国程序员和企业提供企业级一体化 DevOps 平台&#xff0c;用来帮助用户实现需求管理、源代码托管、CI/CD、安全合规&#xff0c;而且所有的操作都是在一个平台上进行&#xff0c;省事省心省钱。可以一键安装极狐GitL…

深度学习参数管理

1.访问参数 我们从已有模型中访问参数。当通过Sequential类定义模型时&#xff0c;我们可以通过索引来访问模型的任意层。 检查第二个全连接层的参数。 print(net[2].state_dict()) print(net[2].bias) print(net[2].bias.data) net[2].weight print(*[(name, param.sh…

vue part 11

vuex的模块化与namespace 115_尚硅谷Vue技术_vuex模块化namespace_1_哔哩哔哩_bilibili 116_尚硅谷Vue技术_vuex模块化namespace_2_哔哩哔哩_bilibili vue-router路由 很常见的很重要的应用&#xff1a;Ajax请求&#xff0c;将响应的数据替换掉原先的代码从而实现不跳转页面…

分布式计算技术是什么?在数据集成值得作用?

数据是现代科技技术的基础&#xff0c;面对爆炸性数据的增长&#xff0c;要求计算能力要求更高、数据整合和处理更有效&#xff0c;如何应对数据集成带来的挑战&#xff1f;本文将探讨分布式计算技术在数据集成中的优化作用。 一 分布式计算技术。 定义&#xff1a;分布式计算…

Qt 模型视图(三):视图类QAbstractItemView

文章目录 Qt 模型视图(三):视图类QAbstractItemView1.基本概念1.1.使用现有视图1.2.使用模型1.3.使用模型的多个视图1.4.在视图之间共享选择 Qt 模型视图(三):视图类QAbstractItemView ​ 模型/视图结构是一种将数据存储和界面展示分离的编程方法。模型存储数据&#xff0c;视…