序言:创建定时任务非常简单,主要有两种创建方式:
- 基于注解(@Scheduled)
- 基于接口(SchedulingConfigurer)
前者相信大家都很熟悉,但是实际使用中我们往往想从数据库中读取指定时间来动态执行定时任务,这时候基于接口的定时任务就大派用场了。
一、静态定时任务(基于注解)
基于注解来创建定时任务非常简单,只需几行代码便可完成。
@Scheduled 除了支持灵活的参数表达式cron之外,还支持简单的延时操作,例如 fixedDelay ,fixedRate 填写相应的毫秒数即可。
1 | import org.springframework.context.annotation.Configuration; |
1 | Cron表达式参数分别表示: |
启动应用,可以看到控制台的信息如下:
使用Scheduled 确实很方便,但缺点是当我们调整了执行周期的时候,需要重启应用才能生效,这多少有些不方便。为了达到实时生效的效果,可以使用接口来完成定时任务。
二、动态定时任务(基于接口)
这里选用 Mysql数据库 和 Mybatis 来查询和调整定时任务的执行周期,然后观察定时任务的执行情况。
1.添加数据库记录
这里我已经在数据库中创建了一个表,内容和结构如下:
2.创建定时器
数据库准备好数据之后,我们编写定时任务,注意这里添加的是TriggerTask,目的是循环读取我们在数据库设置好的执行周期,以及执行相关定时任务的内容。具体代码如下:
1 | import com.exam.service.ExamCronService; |
3. 动态修改执行周期
这里我数据库默认修改成了0/1 * * * * ?
启动应用后,查看控制台,打印时间是我们预期的每1秒一次,等一段时间后将执行周期修改为每2秒执行一次后,控制台打印如下图,查看控制台,发现执行周期已经改变,并且不需要我们重启应用,十分方便