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

论坛 期权论坛 脚本     
匿名技术用户   2020-12-27 00:30   31   0

面对问题:

时时刻刻产生订单。需要定时任务扫描。相对间隔是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 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP