定时任务quartz应用场景及问题解决

应用场景:

客户每隔一段时间执行一次flinkssql的批任务,具体有四个场景:

  1. 一次性:选择一个时间点上线任务。
  2. 间隔周期:选择一个时间点,选定一个间隔小时数和一个间隔分钟数,在时间点首次触发,之后每隔间隔小时和间隔分钟执行一次,例如在2021-08-13 12:00:00上线,之后每隔1h30m执行一次。
  3. 时间周期:选择一个上线日期,一个上线时间点,例如上线日期选择2021-8-13,时间点选择12:00,则在2021-08-13的12:00首次执行,如果当前时间已经超过12:00则在次日的12:00首次执行,之后在每天的12:00执行。
  4. 自定义:填写一个cron表达式,根据表达式执行。

解决方案:

使用quartz定时任务框架,这里有一篇我觉得入门不错的文章供大家学习:Sping整合quartz框架定时任务
针对上述四个具体场景:一次性可以选用SimpleTrigger或者CronTrigger,间隔周期中因为混用了小时数和分钟数,所以用不了CronTrigger,用SimpleTrigger也是十分合适的,时间周期和自定义这两个场景用CronTrigger非常合适。

实现思路:

调用上线接口时,调用定时任务上线接口,在定时任务中编写对应的trigger和job,调用下线接口时,删除对应trigger和job。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值