Springboot中spring-boot-starter-quartz的使用及說(shuō)明
前言
在做定時(shí)任務(wù)時(shí),有需求是把定時(shí)執(zhí)行cron表達(dá)式存在數(shù)據(jù)庫(kù)中,通過(guò)更改數(shù)據(jù)庫(kù)中的值,來(lái)改變?nèi)蝿?wù)執(zhí)行的頻率。
一、添加pom.xml依賴
<!--定時(shí)器依賴-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-quartz</artifactId>
</dependency>
<!--mybatis插件-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
<!--數(shù)據(jù)庫(kù)連接插件-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.13</version>
<scope>runtime</scope>
</dependency>二、application.properties添加數(shù)據(jù)庫(kù)信息
spring.datasource.url:jdbc:mysql://localhost:3306/test?setUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false spring.datasource.username:root spring.datasource.password:root
三、數(shù)據(jù)庫(kù)操作
1.創(chuàng)建數(shù)據(jù)庫(kù)test和表cron
SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for cron -- ---------------------------- DROP TABLE IF EXISTS `cron`; CREATE TABLE `cron` ( `id` int NOT NULL AUTO_INCREMENT, `cron` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL, PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Records of cron -- ---------------------------- INSERT INTO `cron` VALUES (1, '0/5 * * * * ? *');
cron表:

2.創(chuàng)建cron表對(duì)應(yīng)的實(shí)體類
public class CronModel {
private String cron;
public String getCron() {
return cron;
}
public void setCron(String cron) {
this.cron = cron;
}
}
3.創(chuàng)建Mapper
@Mapper
public interface CronModelMapper {
@Select("select cron from cron where id = 1")
String getCron();
}
4.創(chuàng)建Service
@Service
public class CronModelService {
@Autowired
CronModelMapper cronModelMapper;
public String getCron() {
return cronModelMapper.getCron();
}
}
二、Quartz相關(guān)
1.創(chuàng)建JobConfig類
/**
* Quartz的相關(guān)配置,注冊(cè)JobDetail和Trigger
* 注意JobDetail和Trigger是org.quartz包下的,不是spring包下的,不要導(dǎo)入錯(cuò)誤
*/
@Configuration
public class JobConfig {
@Autowired
CronModelService cronModelService;
@Bean
public JobDetail jobDetail() {
JobDetail jobDetail = JobBuilder.newJob(Job.class)
.withIdentity("jobDetail", "jobDetail")
.storeDurably()
.build();
return jobDetail;
}
@Bean
public Trigger trigger() {
Trigger trigger = TriggerBuilder.newTrigger()
.forJob(jobDetail())
.withIdentity("trigger", "trigger")
.startNow()
// 每天0點(diǎn)執(zhí)行
.withSchedule(CronScheduleBuilder.cronSchedule(cronModelService.getCron()))
.build();
return trigger;
}
}2.創(chuàng)建Job類
@Component
public class Job extends QuartzJobBean {
Logger logger = LoggerFactory.getLogger(Job.class);
@Autowired
CronModelService cronModelService;
@Autowired
private Scheduler scheduler;
@Override
protected void executeInternal(JobExecutionContext jobExecutionContext) {
logger.info("執(zhí)行");
Trigger trigger = jobExecutionContext.getTrigger();
String cron = cronModelService.getCron();
try {
CronTrigger cronTrigger = (CronTrigger)
scheduler.getTrigger(trigger.getKey());
String cronExpression = cronTrigger.getCronExpression();
if (!cron.equals(cronExpression)) {
//創(chuàng)建表達(dá)式調(diào)度器
CronScheduleBuilder cronSchedule =
CronScheduleBuilder.cronSchedule(cron);
//重構(gòu)
cronTrigger = cronTrigger.getTriggerBuilder()
.withIdentity(trigger.getKey())
.withSchedule(cronSchedule)
.build();
scheduler.rescheduleJob(trigger.getKey(), cronTrigger);
}
} catch (SchedulerException e) {
e.printStackTrace();
}
}
}總結(jié)
和之前引入quartz包(參考Quartz文檔)不同之處在于,之前是要先定義好Job和Trigger,然后通過(guò)Scheduler去綁定他們,最后去執(zhí)行start來(lái)開啟定時(shí)任務(wù)。
而spring-boot-starter-quartz則省去了Job和Trigger的手動(dòng)綁定(參考鏈接: SpringBoot官方文檔),也就是做好2.1配置即可。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java設(shè)計(jì)模式-單例模式實(shí)現(xiàn)方法詳解
單例模式,屬于創(chuàng)建類型的一種常用的軟件設(shè)計(jì)模式。通過(guò)單例模式的方法創(chuàng)建的類在當(dāng)前進(jìn)程中只有一個(gè)實(shí)例(根據(jù)需要,也有可能一個(gè)線程中屬于單例2021-07-07
踩坑批量更新sql報(bào)錯(cuò),實(shí)際sql能夠正常執(zhí)行的問(wèn)題
在項(xiàng)目工程遷移過(guò)程中,遇到了一個(gè)批量更新接口在新工程中報(bào)錯(cuò)的問(wèn)題,通過(guò)分析,排除了代碼錯(cuò)誤的可能,最終發(fā)現(xiàn)是由于數(shù)據(jù)庫(kù)連接配置不當(dāng)導(dǎo)致的,在jdbc連接字符串中加入allowMultiQueries=true參數(shù)后,問(wèn)題得以解決,這個(gè)參數(shù)的作用是允許SQL批量執(zhí)行2022-12-12
使用IDEA開發(fā)配置Java Web的初始化過(guò)程
該教程使用idea開發(fā)工具初始化javaweb項(xiàng)目,該運(yùn)行在tomcat服務(wù)器上通過(guò)配置項(xiàng)目環(huán)境變量保證tomcat正常啟動(dòng),具體操作配置教程參考下本文2021-06-06
Java數(shù)據(jù)脫敏實(shí)現(xiàn)的方法總結(jié)
數(shù)據(jù)脫敏,指的是對(duì)某些敏感信息通過(guò)脫敏規(guī)則進(jìn)行數(shù)據(jù)的變形,實(shí)現(xiàn)敏感隱私數(shù)據(jù)的可靠保護(hù),本文主要是對(duì)后端數(shù)據(jù)脫敏實(shí)現(xiàn)的簡(jiǎn)單總結(jié),希望對(duì)大家有所幫助2023-07-07
Java調(diào)用第三方接口示范的實(shí)現(xiàn)
這篇文章主要介紹了Java調(diào)用第三方接口示范的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
一文帶你了解微服務(wù)架構(gòu)中的"發(fā)件箱模式"
微服務(wù)架構(gòu)如今非常的流行,這個(gè)架構(gòu)下可能經(jīng)常會(huì)遇到“雙寫”的場(chǎng)景。本文就和大家分享一個(gè)“發(fā)件箱模式”,?感興趣的小伙伴可以了解一下2023-01-01

