Heim >Java >javaLernprogramm >So integrieren Sie Quartz in SpringBoot
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-quartz</artifactId> <version>2.5.2</version> </dependency>
Quartz ist ein Framework für geplante Aufgaben, das häufig in Einzelanwendungsprojekten verwendet wird. Die geplanten Aufgaben können hauptsächlich unterteilt werden in:
Aufgaben im Speicher : Im Allgemeinen im Projekt definiert und gespeichert. Wenn das Projekt neu gestartet wird und die Aufgabe nicht automatisch ausgeführt wird, wird sie nicht erneut gestartet.
Persistente Aufgaben: Speichern Sie die Eigenschaften der Aufgabe in der Datenbank. Nach dem Neustart des Projekts kann die ursprünglich ausgeführte Aufgabe erneut gelesen und ausgeführt werden.
corn
wird verwendet, um den Zeitpunkt zu steuern, zu dem eine Aufgabe ausgelöst wird. corn
是用来控制任务触发的时刻。
我列举一些常用的:
每秒钟触发
"* * * * * *":
每隔5秒执行一次
*/5 * * * * ?
每分钟触发
"0 * * * * ?"
每一小时触发
"0 * * * * ?"
每天10点触发一次
"0 0 10 * * ?"
每天0点触发一次
"0 0 0 * * ?"
需要在启动类上加上@EnableScheduling
注解。
直接定义一个执行任务,例如:
每秒都输出测试
@Service public class ScheduleTest { @Scheduled(cron = "0/1 * * * * *") public void test() { System.out.println("测试"); } }
启动类:
@SpringBootApplication @EnableScheduling public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
启动后看控制台中就会输出相应的内容。
这里需要我们自己定义任务。
通过实现Job
接口,即可定义一个任务,并且我们可以手动去控制这个任务的开启。
public class SimpleJob implements Job { @Override public void execute(JobExecutionContext context) { System.out.println("自定义任务"); } }
导入依赖:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.3.6.RELEASE</version> </dependency>
编写Controller,这是一个固定的写法。
指定任务: JobBuilder.newJob(任务.class) .withIdentity(任务名, 任务组).build();
指定cron表达式,创建Trigger:
CronScheduleBuilder.cronSchedule(cron表达式);
TriggerBuilder.newTrigger().withIdentity(启动器的名字, 启动器的分组) .withSchedule(cron).build();
调用任务:scheduler.scheduleJob(任务类型对象, 启动器对象)
/** * @ClassName * @Description * @Author:chengyunlai * @Date * @Version 1.0 **/ @RestController public class DynamicScheduleController { @Autowired private Scheduler scheduler; @GetMapping("/addSchedule") public String addSchedule() throws SchedulerException { int random = ThreadLocalRandom.current().nextInt(1000); // 1. 创建JobDetail,指定定时任务实现类的类型 JobDetail jobDetail = JobBuilder.newJob(SimpleJob.class) .withIdentity("test-schedule" + random, "test-group").build(); // 2. 创建Trigger,并指定每3秒执行一次 CronScheduleBuilder cron = CronScheduleBuilder.cronSchedule("0/3 * * * * ?"); Trigger trigger = TriggerBuilder.newTrigger().withIdentity("test-trigger" + random, "test-trigger-group") .withSchedule(cron).build(); // 3. 调度任务 scheduler.scheduleJob(jobDetail, trigger); return "success"; }
通过浏览器输入项目的地址,一般默认是localhost:8080/addSchedule
,输入后即可看到控制台输出了任务执行的输出内容。
如果工程重启了,上面的SimpleJob
这个定时任务并不会重新启动。解决的办法就是将任务持久化,Quartz
提供了解决方案,SpringBoot简化了这个操作。我们只需要配置好:数据库、数据源、操作数据库的JDBC即可。
依赖:
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.2.8</version> </dependency>
使用mysql数据库:导入它的驱动,mysql-connector-java。
使用Druid作为我们的数据源:druid。
使用spring-jdbc,帮助我们自动将任务信息存入到数据库中。
# 设置将定时任务的信息保存到数据库 spring.quartz.job-store-type=jdbc # 每次应用启动的时候都初始化数据库表结构 # 如果 spring.quartz.jdbc.initialize-schema 设置为 always 的话有个问题:每次重启应用的时候,跟 Quartz 相关的表会被删除重建! # 所以为了避免表被重复创建,我们可以提前创建表,然后将其指定为never spring.quartz.jdbc.initialize-schema=never # 数据库配置 spring.datasource.type=com.alibaba.druid.pool.DruidDataSource spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/scheduled?serverTimezone=GMT%2B8&useSSL=false&characterEncoding=utf-8 spring.datasource.username=root spring.datasource.password=root
官网:Downloads (quartz-scheduler.org)
以我:quartz-2.3.0-SNAPSHOT为例子:
下载源码后,找到jdbcjobstore
这个目录:
quartz-2.3.0-SNAPSHOTsrcorgquartzimpljdbcjobstore
然后会有一系列的sql
文件,找到和你数据库匹配的那个sql文件即可,我用的是mysql。
执行SQL文件建表,我的数据库名是:scheduled
,各位从我的url中应该也能看出来。
建表完成后,所有配置工作结束了,启动程序,重新在浏览器中输入:localhost:8080/addSchedule
,然后刷新一下数据库,就会发现任务被持久化了,此时重启工程后,该任务依旧会自动执行。
我们在手动开启该任务的时候会指定:
任务的名称和组
JobDetail jobDetail = JobBuilder.newJob(SimpleJob.class) .withIdentity(任务名,任务组).build();
在暂停和恢复任务时,就需要用JobKey.jobKey(任务名,任务组)
,得到一个JobKey
,然后使用scheduler.pauseJob(jobkey)
即可暂停任务;scheduler.resumeJob(jobKey)
恢复任务。
删除任务的时候需要将任务和Trigger都删除,而在上面我们可以拿到这个jobkey
表示任务,我们也需要拿到trigger,同样的我们也定义过启动器的名字和分组。
`TriggerBuilder.newTrigger().withIdentity(启动器的名字, 启动器的分组) .withSchedule(cron).build();`
TriggerKey.triggerKey((启动器的名字, 启动器的分组);
也可以拿到trigger
// 暂停 @GetMapping("/pauseSchedule") public String pauseSchedule(String jobName, String jobGroup) throws SchedulerException { JobKey jobKey = JobKey.jobKey(jobName, jobGroup); // 获取定时任务 JobDetail jobDetail = scheduler.getJobDetail(jobKey); if (jobDetail == null) { return "error"; } scheduler.pauseJob(jobKey); return "success"; } // 恢复 @GetMapping("/remuseSchedule") public String remuseSchedule(String jobName, String jobGroup) throws SchedulerException { JobKey jobKey = JobKey.jobKey(jobName, jobGroup); // 获取定时任务 JobDetail jobDetail = scheduler.getJobDetail(jobKey); if (jobDetail == null) { return "error"; } scheduler.resumeJob(jobKey); return "success"; } // 删除定时任务 @GetMapping("/removeSchedule") public String removeSchedule(String jobName, String jobGroup, String triggerName, String triggerGroup) throws SchedulerException { TriggerKey triggerKey = TriggerKey.triggerKey(triggerName, triggerGroup); JobKey jobKey = JobKey.jobKey(jobName, jobGroup); Trigger trigger = scheduler.getTrigger(triggerKey); if (trigger == null) { return "error"; } // 停止触发器 scheduler.pauseTrigger(triggerKey); // 移除触发器 scheduler.unscheduleJob(triggerKey); // 删除任务 scheduler.deleteJob(jobKey); return "success"; }🎜🎜 🎜Trigger jede Stunde 🎜🎜🎜 rrreee🎜🎜🎜Einmal täglich um 10 Uhr ausgelöst🎜🎜🎜rrreee🎜🎜🎜Einmal täglich um 0 Uhr ausgelöst🎜🎜🎜rrreee🎜Allgemein🎜🎜Sie müssen den
@EnableScheduling
hinzufügen > Anmerkung zur Startup-Klasse. 🎜🎜Speicheraufgabe🎜test
jede Sekunde ausgeben🎜rrreee🎜Startup-Klasse: 🎜 rrreee🎜Nach dem Start wird der entsprechende Inhalt in der Konsole ausgegeben. 🎜Job
-Schnittstelle können wir eine Aufgabe definieren und das Öffnen dieser Aufgabe manuell steuern. 🎜rrreeeJobBuilder.newJob(task.class) .withIdentity(task name, task group).build();
🎜🎜🎜🎜Geben Sie den Cron-Ausdruck an und erstellen Sie einen Trigger: 🎜🎜 CronScheduleBuilder.cronSchedule(cron expression);
🎜🎜🎜🎜TriggerBuilder.newTrigger().withIdentity(the name of the Launcher, Gruppierung von Startern) .withSchedule(cron).build();
🎜🎜🎜🎜🎜Aufgabe aufrufen: scheduler.scheduleJob (Aufgabentypobjekt, Starterobjekt)
🎜🎜🎜rrreee 🎜Geben Sie die Adresse des Projekts über den Browser ein. Der Standardwert ist normalerweise localhost:8080/addSchedule
. Nach der Eingabe können Sie sehen, dass die Konsole den Ausgabeinhalt der Aufgabenausführung ausgibt. 🎜🎜Persistenz🎜🎜Wenn das Projekt neu gestartet wird, wird die geplante Aufgabe SimpleJob
oben nicht neu gestartet. Die Lösung besteht darin, die Aufgabe beizubehalten. Quartz
bietet eine Lösung. Wir müssen nur Folgendes konfigurieren: Datenbank, Datenquelle und JDBC, um die Datenbank zu betreiben. 🎜🎜Abhängigkeiten: 🎜rrreee🎜🎜🎜MySQL-Datenbank verwenden: Importieren Sie den Treiber MySQL-Connector-Java. 🎜🎜🎜🎜Wir verwenden Druid als unsere Datenquelle: Druid. 🎜🎜🎜🎜Verwenden Sie spring-jdbc, um uns dabei zu helfen, Aufgabeninformationen automatisch in der Datenbank zu speichern. 🎜🎜🎜jdbcjobstore
: 🎜🎜quartz-2.3.0-SNAPSHOTsrcorgquartzimpljdbcjobstore
🎜🎜 Dann wird es eine Reihe von sql code>-Datei, suchen Sie einfach die SQL-Datei, die zu Ihrer Datenbank passt. Ich verwende MySQL. 🎜🎜🎜🎜Führen Sie die zu erstellende SQL-Datei aus die Tabelle, I. Der Datenbankname lautet: scheduled
, Sie sollten ihn über meine URL sehen können. 🎜🎜Nachdem die Tabellenerstellung abgeschlossen ist, sind alle Konfigurationsarbeiten abgeschlossen. Starten Sie das Programm und geben Sie erneut Folgendes ein: localhost:8080/addSchedule
. Aktualisieren Sie dann die Datenbank und Sie werden feststellen, dass die Aufgabe erledigt ist Nach einem Neustart des Projekts zu diesem Zeitpunkt wird die Aufgabe weiterhin automatisch ausgeführt. 🎜🎜Aufgaben anhalten und Aufgaben löschen🎜🎜Wenn wir die Aufgabe manuell öffnen, geben wir Folgendes an: 🎜🎜🎜🎜Den Namen und die Gruppe der Aufgabe🎜🎜🎜rrreee🎜Beim Anhalten und Fortsetzen einer Aufgabe müssen Sie verwenden JobKey.jobKey (Aufgabenname, Aufgabengruppe)
, holen Sie sich einen JobKey
und verwenden Sie dann scheduler.pauseJob(jobkey)
, um die Aufgabe anzuhalten; Scheduler.resumeJob( jobKey)Setzen Sie die Aufgabe fort. 🎜🎜🎜🎜Wenn Sie eine Aufgabe löschen, müssen Sie sowohl die Aufgabe als auch den Auslöser löschen. Oben können wir den jobkey
abrufen, um die Aufgabe darzustellen Außerdem wurden der Name und die Gruppierung des Launchers definiert. 🎜🎜🎜rrreee🎜TriggerKey.triggerKey((Name des Launchers, Gruppe des Launchers);
Sie können auch trigger
erhalten, um den Launcher darzustellen.🎜通过以下顺序完整删除任务
scheduler.deleteJob(jobKey);
scheduler.unscheduleJob(triggerKey);
scheduler.pauseTrigger(triggerKey);
// 停止触发器
// 移除触发器
// 删除任务
// 暂停 @GetMapping("/pauseSchedule") public String pauseSchedule(String jobName, String jobGroup) throws SchedulerException { JobKey jobKey = JobKey.jobKey(jobName, jobGroup); // 获取定时任务 JobDetail jobDetail = scheduler.getJobDetail(jobKey); if (jobDetail == null) { return "error"; } scheduler.pauseJob(jobKey); return "success"; } // 恢复 @GetMapping("/remuseSchedule") public String remuseSchedule(String jobName, String jobGroup) throws SchedulerException { JobKey jobKey = JobKey.jobKey(jobName, jobGroup); // 获取定时任务 JobDetail jobDetail = scheduler.getJobDetail(jobKey); if (jobDetail == null) { return "error"; } scheduler.resumeJob(jobKey); return "success"; } // 删除定时任务 @GetMapping("/removeSchedule") public String removeSchedule(String jobName, String jobGroup, String triggerName, String triggerGroup) throws SchedulerException { TriggerKey triggerKey = TriggerKey.triggerKey(triggerName, triggerGroup); JobKey jobKey = JobKey.jobKey(jobName, jobGroup); Trigger trigger = scheduler.getTrigger(triggerKey); if (trigger == null) { return "error"; } // 停止触发器 scheduler.pauseTrigger(triggerKey); // 移除触发器 scheduler.unscheduleJob(triggerKey); // 删除任务 scheduler.deleteJob(jobKey); return "success"; }
Das obige ist der detaillierte Inhalt vonSo integrieren Sie Quartz in SpringBoot. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!