查看: 1589|回复: 1

[转载] 在taskctl里做定时任务时,是用翻牌机制好还是用定时器好呢?

[复制链接]
发表于 2017-9-11 11:32 | 显示全部楼层 |阅读模式
本帖最后由 快崩溃的小马甲 于 2017-9-11 11:34 编辑

我们来先看看用“condition+modivarv ”的翻牌机制与定时器 做定时调度的大致步骤。

1、在流程容器中采用condition+modivarv来定时调度(作业)。

其原理是通过流程自身的定时条件判断来实现的,如下代码:

  1.   <nulljob>
  2.     <name>startctljob</name>
  3.     <jobdesc>启动触发控制节点</jobdesc>
  4.     <condition>if($(startdatetime)<systime('yyyymmddhhmiss')) CTL_DOIT else CTL_WAIT</condition>
  5.   </nulljob>
  6.   <!--
  7.       调实际业务流程
  8.    -->
  9.   <flow>
  10.     <name>callbussflow</name>
  11.     <progname>Demo_zbussflow</progname>
  12.     <jobdesc>调实际业务处理流程</jobdesc>
  13.   </flow>
  14.   <!--
  15.        一、最后修改下次启动时间变量,通过modivarv任务类型实现
  16.        二、范例中表示每天定时启动: $(addday($(startdatetime), 'yyyymmddhhmiss', 1)
  17.        三、其他周期表达如下:
  18.            1. 每个5分钟:$(addminute($(startdatetime), 'yyyymmddhhmiss',5)
  19.            2. 每隔8小时:$(addhour($(startdatetime), 'yyyymmddhhmiss',8)
  20.     -->
  21.   <modivarv>
  22.     <name>passflow</name>
  23.     <para>varname=startdatetime,varvalue=$(addday('$(startdatetime)', 'yyyymmddhhmiss', 1))</para>
  24.     <jobdesc>翻牌:修改变量</jobdesc>
  25.   </modivarv>
复制代码

2、在定时器容器中使用timingplan属性来实现定时功能。如下代码:

  1.   <!--
  2.       每5分钟启动: <timingplan>* m 5</timingplan>
  3.       每5秒启动:<timingplan>* s 5</timingplan>
  4.       每5小时启动:<timingplan>* h 5</timingplan>
  5.       每天10点1分1秒启动:<timingplan>100101 d 1</timingplan>
  6.   -->
  7.   <flow>
  8.     <name>callbussflow</name>
  9.     <progname>Demo_zbussflow</progname>
  10.     <timingplan>* m 5</timingplan>
  11.     <jobdesc>调实际业务处理流程</jobdesc>
  12.   </flow>
复制代码

我们可以看到,使用定时器的timingplan属性来处理定频定时的调度更简单、也更直观。这对于初学者也能够很好的理解定时调度,而且操作起来更方便。

这两种方式都是可以用来作为定时调度的方法。采用“condition+modivarv翻牌机制”更灵活,采用“定时器timingplan属性”更直观。如果是简单定时定频的调度逻辑,我们推荐采用“定时器timingplan属性”。


论坛徽章:
0
发表于 2017-9-11 17:37 | 显示全部楼层
不错,不错,感谢分享。

使用道具 举报

回复

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

PostgreSQL中国大会,参会票抢购!

由 PostgreSQL中文社区与ITPUB联合主办的第九届《PostgreSQL 中国技术大会》将在北京隆重召开。PostgreSQL 作为功能最强的的开源关系型数据库之一,得到了越来越多企业的推广和运用,也越来越受到广大技术爱好者的欢迎和重视。这将是 PostgreSQL 的又一次交流盛会。
----------------------------------------
时间:2019年11月29~11月30日

点击报名>>
TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档
  ChinaUnix | ChinaUnix博客 | ChinaUnix论坛
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 
京ICP备09055130号-4  北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表