写点什么

TASKCTL 作业流程与模块之间的区别

作者:TASKCTL
  • 2022 年 4 月 18 日
  • 本文字数:928 字

    阅读完需:约 3 分钟

TASKCTL 作业流程与模块之间的区别

​主流程、子流程、定时器都属于控制容器;而每个控制容器,包含一个或多个模块;在模块中定义具体的作业。

主流程、子流程、定时器、模块之间的关系

主流程、子流程、定时器、模块在资源树中的表达:

  • 控制容器:是作业的最大组织单位,是一个独立完整的调度控制主体。在实际运行过程中,每个控制容器也相当于一个程序,在服务端都有一个对应的进程。因此,每个控制容器在 Monitor 中,都具有独立启停(激活)操作的特性。

  • 模块:在TASKCTL中, 流程、定时器的作业定义信息是通过 xml 格式代码组织的,而具体代码信息是又存放在每一个模块文件中。同时,为了方便管理,一个流程或定时器也可以由多个模块代码信息构成。其次,像程序一样。每个程序都有一个入口 main 函数类,而TASKCTL流程也有一个主模块入口。

  • 流程与定时器:流程与定时器是不同的控制容器, 有一个明显的概念区分。流程对作业的组织是有序的,而定时器是无序的,作业之间不存在关系。TASKCTL,就是通过有序与无序这两种组织形式,形成了一个相对完整的控制器体系。

  • 主流程与子流程:从技术的角度,主流程相当于一个守护进程,一旦运行,除非人为或异常退出,它就常驻内存,其流程内部是一个死循环,从开始运行到结束,又再次循环;而子流程,就相对于一个普通程序,运行结束后,相应的进程也会自动退出。


主流程、子流程、定时器的主要用途与应用场景

  1. 总体上讲,具有先后逻辑关系的作业用流程来组织,而不具有逻辑关系且离散的作业(只具有不同时间频度的作业)用定时器来组织。

  2. 子流程,主要用于业务逻辑作业流的组织;主流程,一般用于逻辑触发控制,用于触发子流程的调用

用几个例子,加深对主流程、子流程、定时器的主要用途与应用场景的理解

离散调用处理用定时器

业务子流程

​用子流程来组织具体的业务处理流程


触发控制主流程


主流程主要用于流程的触发控制,本例是文件达到触发控制。


实际上,业务子流程的触发控制,如果是简单的定时触发,建议采用定时器;但如果是一些比较复杂的流程触发控制,就得采用主流程来触发控制。


一个复杂的主流程触发控制例子

对应代码


该例子为每周 【 1,3,4 】 的 【 8,10,16 】 点阶段运行调用 “我的业务处理流程”

产品地址:www.taskctl.com


去公众号【TASKCTL】可直接获取产品官方永久使用授权;

用户头像

TASKCTL

关注

公众号:【TASKCTL】官方免费直接授权使用 2020.12.23 加入

一款B/S架构的轻量级ETL调度处理工具;支持各类脚本任务程序和扩展;具备可视化图形拖拽设计界面以及可视化任务管理、计划调度、实时监控、消息预警和日志分析;有效弥补了传统ETL工具在调度管理和监控分析方面不足

评论

发布
暂无评论
TASKCTL 作业流程与模块之间的区别_Docker_TASKCTL_InfoQ写作平台