业务场景
需求上要求能实现quartz的simpleTrigger任务,同时还需要动态的创建任务而非在控制面板上创建,查阅xxl-job官方文档发现simpelTrigger其暂时还躺在to do list,而动态创建可以调用JobInfoController
其add和start接口(但是有个弊端,start/stop/remove等方法都只要求传送id,这点上可以自己扩展接口实现),还需要放开登录权限,接下来就老夫上去就上一梭子,开干。
job_info字段调整说明
1 | CREATE TABLE `XXL_JOB_QRTZ_TRIGGER_INFO` ( |
- job_cron设为空,支持simpleTrigger;
- ext_reamrk自定义扩展字段,可以根据它来刷选job从而避免start/stop/remove接口只有id作为参数;
- job_repeat_count,simplerTrigger的执行次数,默认-1即为无限次,0的话是执行1次;
- job_repeat_interval,simplerTrigger每次执行的时间间隔,单位毫秒;
- job_start_time,trigger开始时间和当前时间的时间间隔,单位毫秒;
- job_end_time,trigger结束时间
重写启动任务
xxl-job在新建任务的时候只是把job数据保存到数据库里,只有启动的时候才会创建jobDetail
和trigger
并由scheduler
来启动job。
重写XxlJobDynamicScheduler
的addJob
方法:根据jobInfo中的值构建cron的trigger还是simple的trigger。
1 | public static boolean addJob(XxlJobInfo xxlJobInfo) throws SchedulerException { |
效果图
可以看到将数据库里3任务改为间隔3秒,job_repeat_count为1,任务实际会执行2次。
额外的工作
- 虽然支持cron或simple,但是在控制台节目只能维护cron的trigger,并且优先cron,同时cron设为可以为空,但是管理平台上没有simple的相关数据,如果需要的话要重新修改对应的页面和add和update的逻辑;
- job状态取的是trigger的状态,所以可能看到的是simpleTrigger的状态。
- 目前job的trigger是在cron和simple中二者取一,但是也可以扩展启动任务的方法,使其支持扩展多trigger,但是triggerKey需要重新定义而非取jobName(因为trigger的hash是triggerKey的hash),本身xxl-job的jobKey取的是job的id,triggerKey取的也是job的id,没有使用到groupName。