(一)xxl-job介绍以及搭建过程
(二)xxl-job执行器端的执行器自动注册原理
(三)xxl-job调度器端的执行器自动注册原理
(四)xxl-job任务管理以及调度器端任务手动执行的原理
(五)xxl-job调度器端任务启动执行的原理
(六)xxl-job执行器端接收调度器任务执行的原理
1、在任务管理模块里面可以新增任务,可以执行任务、启动任务、编辑任务。同时可以查看任务日志。
2、我们看一下相关代码
3、基本都是数据库的增删改查,我们重点研究一下start(),stop()和triggerJob()
1)任务停止
@Override
public ReturnT<String> stop(int id) {
//从数据库表中查找到任务详情
XxlJobInfo xxlJobInfo = xxlJobInfoDao.loadById(id);
//修改三个字段
//调度状态:0-停止,1-运行
xxlJobInfo.setTriggerStatus(0);
//上次调度时间
xxlJobInfo.setTriggerLastTime(0);
//下次调度时间
xxlJobInfo.setTriggerNextTime(0);
xxlJobInfoDao.update(xxlJobInfo);
return ReturnT.SUCCESS;
}
2)任务开始运行
public ReturnT<String> start(int id) {
XxlJobInfo xxlJobInfo = xxlJobInfoDao.loadById(id);
// next trigger time (5s后生效,避开预读周期)
long nextTriggerTime = 0;
try {
Date nextValidTime = new CronExpression(xxlJobInfo.getJobCron()).getNextValidTimeAfter(new Date(System.currentTimeMillis() + JobScheduleHelper.PRE_READ_MS));
if (nextValidTime == null) {
return new ReturnT<String>(ReturnT.FAIL_CODE, I18nUtil.getString("jobinfo_field_cron_never_fire"));
}
nextTriggerTime = nextValidTime.getTime();
} catch (ParseException e) {
logger.error(e.getMessage(), e);
return new ReturnT<String>(ReturnT.FAIL_CODE, I18nUtil.getString("jobinfo_field_cron_unvalid")+" | "+ e.getMessage());
}
//修改三个字段
//调度状态:0-停止,1-运行
xxlJobInfo.setTriggerStatus(1);
//上次调度时间
xxlJobInfo.setTriggerLastTime(0);
//下次调度时间
xxlJobInfo.setTriggerNextTime(nextTriggerTime);
xxlJobInfoDao.update(xxlJobInfo);
return ReturnT.SUCCESS;
}
3)任务执行一次
private static JobTriggerPoolHelper helper = new JobT