参考文章
http://www.quartz-scheduler.org/documentation/quartz-2.2.x/quick-start.html
http://www.cnblogs.com/daxin/p/3608320.html (quartz任务获取spring bean)
https://blog.csdn.net/running_snail_/article/details/48848229 (持久化定时任务需要单独配置)
https://blog.csdn.net/wk52525/article/details/79100973 (spring boot集成quartz)
在我们需要把quartz的定时任务持久化到数据库的时候,我们首先需要找到quartz提供给的sql,https://github.com/quartz-scheduler/quartz/tree/quartz-2.2.x这个是2.2.x分支里的sql脚本。master分支上是没有的,这点我们需要注意一下。
具体目录如下
找到对应的数据库脚本,笔者这里用的是mysql
具体步骤
1.配置properties文件
spring boot 文档地址https://docs.spring.io/spring-boot/docs/2.0.2.RELEASE/reference/htmlsingle/#boot-features-quartz
2.创建job任务
3.继承AdaptableJobFactory
这里是为了让quartz能获取到spring 维护的bean对象,否者我们的job中是拿不到spring创建的对象,也就不能使用我们通用的dao、service等。
4.创建job对象
5.创建触发器
这里的参数可以不用,但是我们在设置job的时候需要调用第四步的方法。
6.创建计划任务
这里需要注意的是dataSource。我们需要指定quartz的数据元,否者就会创建一个保存在内存中的定时任务,下面分别是内存和数据库的启动的日志
7.配置quartz能够获取到spring维护的bean
这个例子中,我们省去了手动来维护quartz的表操作,完全是quartz自己来维护。网上的资料大多数是自己编写代码来操作quartz的表操作。这样也就完全没有用到quartz自己的实现,有不可预测的风险。
代码地址:码云
不足之处,请纠正