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 AQS中ReentrantReadWriteLock讀寫鎖的使用
ReentrantReadWriteLock稱為讀寫鎖,它提供一個(gè)讀鎖,支持多個(gè)線程共享同一把鎖。這篇文章主要講解一下ReentrantReadWriteLock的使用和應(yīng)用場(chǎng)景,感興趣的可以了解一下2023-02-02Java實(shí)戰(zhàn)之圖書管理系統(tǒng)的實(shí)現(xiàn)
這篇文章主要介紹了如何利用Java語(yǔ)言編寫一個(gè)圖書管理系統(tǒng),文中采用的技術(shù)有Springboot、SpringMVC、MyBatis、ThymeLeaf 等,需要的可以參考一下2022-03-03Java如何獲取對(duì)象屬性及對(duì)應(yīng)值
這篇文章主要介紹了Java如何獲取對(duì)象屬性及對(duì)應(yīng)值,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11SpringCloud?Gateway詳細(xì)分析實(shí)現(xiàn)負(fù)載均衡與熔斷和限流
這篇文章主要介紹了SpringCloud?Gateway實(shí)現(xiàn)路由轉(zhuǎn)發(fā),負(fù)載均衡,熔斷和限流,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07Spring中的@PostConstruct注解使用方法解析
這篇文章主要介紹了Spring中的@PostConstruct注解使用方法解析,@PostConstruct注解是用來(lái)處理在@Autowired注入屬性后init()方法之前,對(duì)一些零散的屬性進(jìn)行賦值的注解,需要的朋友可以參考下2023-11-11