TASKCTL设计作业流时该用定时器还是流程

浏览: 1654

在调度业界中,都有一个跑批的概念。我们通常希望流程在某个时间点开始每天执行一次。比如每天的凌晨1点开始执行一次。在TASKCTL中,有两种方式可以实现该需求。

使用“condition+修改批次变量”

1、首先需要添加日期批次变量,如workdate,并设置变量格式为yyyymmdd,如20170101

2、编写流程模块代码如下:

<serial>
 
<name>MainModul_rootnode</name>
 
<begin>
   
<name>MainModul_beginjob</name>
 
</begin>
 
<nulljob>
   
<name>startctljob</name>
   
<jobdesc>启动触发控制节点</jobdesc>
   
<condition>if($(workdate)&lt;systime('yyyymmdd')and (systime('hh')&gt;='01')) CTL_DOIT else CTL_WAIT</condition>
 
</nulljob>
 
<!-- 用户模块代码自定义区开始 -->
 
<!-- 一个实际的流程 -->
 
<!-- 翻牌修改workdate -->
 
<modivarv>
   
<name>passflow</name>
   
<para>varname=workdate,varvalue=$(addday('$(workdate)','yyyymmdd', 1))</para>
   
<jobdesc>翻牌:修改变量</jobdesc>
 
</modivarv>
 
<end>
   
<name>MainModul_endjob</name>
 
</end>
</serial>

注:在正式启动的流程的时候,需要设置workdate 等于当前系统日期,以保证流程不会多次运行。

使用“定时器+子流程”

1、 首先我们需要把任务组装成一个子流程

添加一个定时器,在定时器中添加任务类型为子流程节点,并调用刚刚设计的子流程,在定时器的频率中添加定时的频率,比如 010000 d 1

推荐 0
本文由 ETL批量调度-Taskctl 创作,采用 知识共享署名-相同方式共享 3.0 中国大陆许可协议 进行许可。
转载、引用前需联系作者,并署名作者且注明文章出处。
本站文章版权归原作者及原出处所有 。内容为作者个人观点, 并不代表本站赞同其观点和对其真实性负责。本站是一个个人学习交流的平台,并不用于任何商业目的,如果有任何问题,请及时联系我们,我们将根据著作权人的要求,立即更正或者删除有关内容。本站拥有对此声明的最终解释权。

0 个评论

要回复文章请先登录注册