面对问题:
时时刻刻产生订单。需要定时任务扫描。相对间隔是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分钟去执行一次。