原文网址:Spring定时任务--手动执行定时任务(替代@Scheduled)
简介
本文介绍SpringBoot如何手动执行定时任务。
之前此文已经介绍过,直接用@Scheduled即可使用Spring的定时任务,但有时需要手动去提交定时任务,比如:
- 从其他位置获取cron配置,无法写到注解。
- 有不确定个数的任务,不能在代码中写死。
方案1:实现 SchedulingConfigurer 接口
本处从数据库读取配置,然后提交定时任务。
创建定时器
编写定时任务,这里添加的是TriggerTask,循环读取我们在数据库设置好的执行周期,以及执行相关定时任务的内容。
@Configuration
@EnableScheduling
public class DynamicScheduleTask implements SchedulingConfigurer {
@Autowired
private CronMapper cronMapper;
/**
* 执行定时任务.
*/
@Override
public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
taskRegistrar.addTriggerTask(
//1.添加任务内容(Runnable)
() -> System.out.println("执行动态定时任务: " + LocalDateTime.now().toLocalTime()),
//2.设置执行周期(Trigger)
triggerContext -> {
//2.1 从数据库获取执行周期
String cron = cronMapper.getCron();
//2.2 合法性校验.
if (StringUtils.isEmpty(cron)) {
// Omitted Code ..
}
//2.3 返回执行周期(Date)
return new CronTrigger(cron).nextExecutionTime(triggerContext);
}
);
}
}
表结构与数据
开启本地数据库mysql,随便打开查询窗口,然后执行脚本内容,如下
DROP DATABASE IF EXISTS `socks`;
CREATE DATABASE `socks`;
USE `SOCKS`;
DROP TABLE IF EXISTS `cron`;
CREATE TABLE `cron` (
`cron_id` varchar(30) NOT NULL PRIMARY KEY,
`cron` varchar(30) NOT NULL
);
INSERT INTO `cron` VALUES ('1', '0/5 * * * * ?');
项目中的application.yml 添加数据源
spring:
datasource:
url: jdbc:mysql://localhost:3306/socks
username: root
password: 123456
启动测试
启动应用后,查看控制台,打印时间是我们预期的每10秒一次:
打开Navicat ,将执行周期修改为每6秒执行一次,如图
如果在数据库修改时格式出现错误,则定时任务会停止,即使重新修改正确;此时只能重新启动项目才能恢复。
方案2:ThreadPoolTaskScheduler
上边的实例的定时任务在SprinBoot在启动时就启动,也可以在代码中任意启动/关闭/调整时间。如下:
上边是文章部分内容,为便于维护,全文已转移到此网址:Spring定时任务-手动执行定时任务(替代@Scheduled) - 自学精灵