定时任务调度--时间轮应用

来源:互联网 发布:森林鸟旗舰店淘宝 编辑:程序博客网 时间:2024/05/21 17:10

面对问题:

     时时刻刻产生订单。需要定时任务扫描。相对间隔是1 2  4 10 ,一期需求是倍数是30秒,每隔 30秒,1分钟,2分钟,5分钟去执行一次。

方案:

     1. 定时任务没隔30秒跑一次,记录每个订单的执行次数。时间间隔相对值

         算法简单,缺点。

         优点:调度频率通过定时任务频率去控制。

         缺点:调度频率能调大,调小时需要传入一个指定时间。

     2 通过时间轮,得到订单的秒数/30,离1973年那个点的秒数。为整数。 将当前时间的秒数/30,两数相减得到的值x,x是否符合 1 2  4 10 (是30秒,1分钟,2分钟,5分钟除以10得到的序列数). 定时任务频率要快,需要记录上一次执行的时间。上次时间/10 和 本次执行时间/10如果相等,这说明该区间已经执行过。不重复执行。

       优点:基本和调度频率无关。调度频率能调大,能调小。只要不调到调度间隔之小

                  定时任务调度频率,能快,能等,但不能慢。如果你一年才执行一次,那最多执行一次了。
解决了大部分问题。

       缺点:频率通过时间轮离散度去控制。不够直观。

问题简化版,面对问题:

     时时刻刻产生订单。需要定时任务扫描。 每隔 30秒,1分钟,2分钟,5分钟去执行一次。

0 0
原创粉丝点击