From f8eb59e9d1351dcdc683936ae7f27e864f6ff053 Mon Sep 17 00:00:00 2001 From: RuoYi Date: Fri, 20 Aug 2021 15:17:09 +0800 Subject: [PATCH] =?UTF-8?q?=E8=A1=A5=E5=85=85=E5=AE=9A=E6=97=B6=E4=BB=BB?= =?UTF-8?q?=E5=8A=A1=E8=A1=A8=E5=AD=97=E6=AE=B5=E6=B3=A8=E9=87=8A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sql/quartz.sql | 364 ++++++++++++------ .../framework/config/ScheduleConfig.java | 114 +++--- 2 files changed, 301 insertions(+), 177 deletions(-) diff --git a/sql/quartz.sql b/sql/quartz.sql index c611688..c1cc304 100644 --- a/sql/quartz.sql +++ b/sql/quartz.sql @@ -1,189 +1,313 @@ +delete from qrtz_fired_triggers; +delete from qrtz_simple_triggers; +delete from qrtz_simprop_triggers; +delete from qrtz_cron_triggers; +delete from qrtz_blob_triggers; +delete from qrtz_triggers; +delete from qrtz_job_details; +delete from qrtz_calendars; +delete from qrtz_paused_trigger_grps; +delete from qrtz_locks; +delete from qrtz_scheduler_state; + +drop table qrtz_calendars; +drop table qrtz_fired_triggers; +drop table qrtz_blob_triggers; +drop table qrtz_cron_triggers; +drop table qrtz_simple_triggers; +drop table qrtz_simprop_triggers; +drop table qrtz_triggers; +drop table qrtz_job_details; +drop table qrtz_paused_trigger_grps; +drop table qrtz_locks; +drop table qrtz_scheduler_state; + -- ---------------------------- -- 1、存储每一个已配置的 jobDetail 的详细信息 -- ---------------------------- create table qrtz_job_details ( - sched_name varchar2(120) not null, - job_name varchar2(200) not null, - job_group varchar2(200) not null, - description varchar2(250) null, - job_class_name varchar2(250) not null, - is_durable varchar2(1) not null, - is_nonconcurrent varchar2(1) not null, - is_update_data varchar2(1) not null, - requests_recovery varchar2(1) not null, - job_data blob null, - constraint qrtz_job_details_pk primary key (sched_name,job_name,job_group) + sched_name varchar2(120) not null, + job_name varchar2(200) not null, + job_group varchar2(200) not null, + description varchar2(250) null, + job_class_name varchar2(250) not null, + is_durable varchar2(1) not null, + is_nonconcurrent varchar2(1) not null, + is_update_data varchar2(1) not null, + requests_recovery varchar2(1) not null, + job_data blob null, + constraint qrtz_job_details_pk primary key (sched_name, job_name, job_group) ); +comment on table qrtz_job_details is '任务详细信息表'; +comment on column qrtz_job_details.sched_name is '调度名称'; +comment on column qrtz_job_details.job_name is '任务名称'; +comment on column qrtz_job_details.job_group is '任务组名'; +comment on column qrtz_job_details.description is '相关介绍'; +comment on column qrtz_job_details.job_class_name is '执行任务类名称'; +comment on column qrtz_job_details.is_durable is '是否持久化'; +comment on column qrtz_job_details.is_nonconcurrent is '是否并发'; +comment on column qrtz_job_details.is_update_data is '是否更新数据'; +comment on column qrtz_job_details.requests_recovery is '是否接受恢复执行'; +comment on column qrtz_job_details.job_data is '存放持久化job对象'; + -- ---------------------------- -- 2、 存储已配置的 Trigger 的信息 -- ---------------------------- create table qrtz_triggers ( - sched_name varchar2(120) not null, - trigger_name varchar2(200) not null, - trigger_group varchar2(200) not null, - job_name varchar2(200) not null, - job_group varchar2(200) not null, - description varchar2(250) null, - next_fire_time number(13) null, - prev_fire_time number(13) null, - priority number(13) null, - trigger_state varchar2(16) not null, - trigger_type varchar2(8) not null, - start_time number(13) not null, - end_time number(13) null, - calendar_name varchar2(200) null, - misfire_instr number(2) null, - job_data blob null, - constraint qrtz_triggers_pk primary key (sched_name,trigger_name,trigger_group), - constraint qrtz_trigger_to_jobs_fk foreign key (sched_name,job_name,job_group) - references qrtz_job_details(sched_name,job_name,job_group) + sched_name varchar2(120) not null, + trigger_name varchar2(200) not null, + trigger_group varchar2(200) not null, + job_name varchar2(200) not null, + job_group varchar2(200) not null, + description varchar2(250) null, + next_fire_time number(13) null, + prev_fire_time number(13) null, + priority number(13) null, + trigger_state varchar2(16) not null, + trigger_type varchar2(8) not null, + start_time number(13) not null, + end_time number(13) null, + calendar_name varchar2(200) null, + misfire_instr number(2) null, + job_data blob null, + constraint qrtz_triggers_pk primary key (sched_name, trigger_name, trigger_group), + constraint qrtz_trigger_to_jobs_fk foreign key (sched_name, job_name, job_group) references qrtz_job_details(sched_name, job_name, job_group) ); +comment on table qrtz_triggers is '触发器详细信息表'; +comment on column qrtz_triggers.sched_name is '调度名称'; +comment on column qrtz_triggers.trigger_name is '触发器的名字'; +comment on column qrtz_triggers.trigger_group is '触发器所属组的名字'; +comment on column qrtz_triggers.job_name is 'qrtz_job_details表job_name的外键'; +comment on column qrtz_triggers.job_group is 'qrtz_job_details表job_group的外键'; +comment on column qrtz_triggers.description is '相关介绍'; +comment on column qrtz_triggers.next_fire_time is '上一次触发时间(毫秒)'; +comment on column qrtz_triggers.prev_fire_time is '下一次触发时间(默认为-1表示不触发)'; +comment on column qrtz_triggers.priority is '优先级'; +comment on column qrtz_triggers.trigger_state is '触发器状态'; +comment on column qrtz_triggers.trigger_type is '触发器的类型'; +comment on column qrtz_triggers.start_time is '开始时间'; +comment on column qrtz_triggers.end_time is '结束时间'; +comment on column qrtz_triggers.calendar_name is '日程表名称'; +comment on column qrtz_triggers.misfire_instr is '补偿执行的策略'; +comment on column qrtz_triggers.job_data is '存放持久化job对象'; + + + -- ---------------------------- -- 3、 存储简单的 Trigger,包括重复次数,间隔,以及已触发的次数 -- ---------------------------- create table qrtz_simple_triggers ( - sched_name varchar2(120) not null, - trigger_name varchar2(200) not null, - trigger_group varchar2(200) not null, - repeat_count number(7) not null, - repeat_interval number(12) not null, - times_triggered number(10) not null, - constraint qrtz_simple_trig_pk primary key (sched_name,trigger_name,trigger_group), - constraint qrtz_simple_trig_to_trig_fk foreign key (sched_name,trigger_name,trigger_group) - references qrtz_triggers(sched_name,trigger_name,trigger_group) + sched_name varchar2(120) not null, + trigger_name varchar2(200) not null, + trigger_group varchar2(200) not null, + repeat_count number(7) not null, + repeat_interval number(12) not null, + times_triggered number(10) not null, + constraint qrtz_simple_trig_pk primary key (sched_name, trigger_name, trigger_group), + constraint qrtz_simple_trig_to_trig_fk foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) ); +comment on table qrtz_simple_triggers is '简单触发器的信息表'; +comment on column qrtz_simple_triggers.sched_name is '调度名称'; +comment on column qrtz_simple_triggers.trigger_name is 'qrtz_triggers表trigger_name的外键'; +comment on column qrtz_simple_triggers.trigger_group is 'qrtz_triggers表trigger_group的外键'; +comment on column qrtz_simple_triggers.repeat_count is '重复的次数统计'; +comment on column qrtz_simple_triggers.repeat_interval is '重复的间隔时间'; +comment on column qrtz_simple_triggers.times_triggered is '已经触发的次数'; + -- ---------------------------- -- 4、 存储 Cron Trigger,包括 Cron 表达式和时区信息 -- ---------------------------- create table qrtz_cron_triggers ( - sched_name varchar2(120) not null, - trigger_name varchar2(200) not null, - trigger_group varchar2(200) not null, - cron_expression varchar2(120) not null, - time_zone_id varchar2(80), - constraint qrtz_cron_trig_pk primary key (sched_name,trigger_name,trigger_group), - constraint qrtz_cron_trig_to_trig_fk foreign key (sched_name,trigger_name,trigger_group) - references qrtz_triggers(sched_name,trigger_name,trigger_group) + sched_name varchar2(120) not null, + trigger_name varchar2(200) not null, + trigger_group varchar2(200) not null, + cron_expression varchar2(120) not null, + time_zone_id varchar2(80), + constraint qrtz_cron_trig_pk primary key (sched_name, trigger_name, trigger_group), + constraint qrtz_cron_trig_to_trig_fk foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) ); +comment on table qrtz_cron_triggers is 'Cron类型的触发器表'; +comment on column qrtz_cron_triggers.sched_name is '调度名称'; +comment on column qrtz_cron_triggers.trigger_name is 'qrtz_triggers表trigger_name的外键'; +comment on column qrtz_cron_triggers.trigger_group is 'qrtz_triggers表trigger_group的外键'; +comment on column qrtz_cron_triggers.cron_expression is 'cron表达式'; +comment on column qrtz_cron_triggers.time_zone_id is '时区'; + -- ---------------------------- -- 5、 Trigger 作为 Blob 类型存储(用于 Quartz 用户用 JDBC 创建他们自己定制的 Trigger 类型,JobStore 并不知道如何存储实例的时候) -- ---------------------------- create table qrtz_blob_triggers ( - sched_name varchar2(120) not null, - trigger_name varchar2(200) not null, - trigger_group varchar2(200) not null, - blob_data blob null, - constraint qrtz_blob_trig_pk primary key (sched_name,trigger_name,trigger_group), - constraint qrtz_blob_trig_to_trig_fk foreign key (sched_name,trigger_name,trigger_group) - references qrtz_triggers(sched_name,trigger_name,trigger_group) + sched_name varchar2(120) not null, + trigger_name varchar2(200) not null, + trigger_group varchar2(200) not null, + blob_data blob null, + constraint qrtz_blob_trig_pk primary key (sched_name, trigger_name, trigger_group), + constraint qrtz_blob_trig_to_trig_fk foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) ); +comment on table qrtz_blob_triggers is 'Blob类型的触发器表'; +comment on column qrtz_blob_triggers.sched_name is '调度名称'; +comment on column qrtz_blob_triggers.trigger_name is 'qrtz_triggers表trigger_name的外键'; +comment on column qrtz_blob_triggers.trigger_group is 'qrtz_triggers表trigger_group的外键'; +comment on column qrtz_blob_triggers.blob_data is '存放持久化Trigger对象'; + -- ---------------------------- -- 6、 以 Blob 类型存储存放日历信息, quartz可配置一个日历来指定一个时间范围 -- ---------------------------- create table qrtz_calendars ( - sched_name varchar2(120) not null, - calendar_name varchar2(200) not null, - calendar blob not null, - constraint qrtz_calendars_pk primary key (sched_name,calendar_name) + sched_name varchar2(120) not null, + calendar_name varchar2(200) not null, + calendar blob not null, + constraint qrtz_calendars_pk primary key (sched_name, calendar_name) ); +comment on table qrtz_calendars is '日历信息表'; +comment on column qrtz_calendars.sched_name is '调度名称'; +comment on column qrtz_calendars.calendar_name is '日历名称'; +comment on column qrtz_calendars.calendar is '存放持久化calendar对象'; + -- ---------------------------- -- 7、 存储已暂停的 Trigger 组的信息 -- ---------------------------- create table qrtz_paused_trigger_grps ( - sched_name varchar2(120) not null, - trigger_group varchar2(200) not null, - constraint qrtz_paused_trig_grps_pk primary key (sched_name,trigger_group) + sched_name varchar2(120) not null, + trigger_group varchar2(200) not null, + constraint qrtz_paused_trig_grps_pk primary key (sched_name, trigger_group) ); +comment on table qrtz_paused_trigger_grps is '暂停的触发器表'; +comment on column qrtz_paused_trigger_grps.sched_name is '调度名称'; +comment on column qrtz_paused_trigger_grps.trigger_group is 'qrtz_triggers表trigger_group的外键'; + -- ---------------------------- -- 8、 存储与已触发的 Trigger 相关的状态信息,以及相联 Job 的执行信息 -- ---------------------------- create table qrtz_fired_triggers ( - sched_name varchar2(120) not null, - entry_id varchar2(95) not null, - trigger_name varchar2(200) not null, - trigger_group varchar2(200) not null, - instance_name varchar2(200) not null, - fired_time number(13) not null, - sched_time number(13) not null, - priority number(13) not null, - state varchar2(16) not null, - job_name varchar2(200) null, - job_group varchar2(200) null, - is_nonconcurrent varchar2(1) null, - requests_recovery varchar2(1) null, - constraint qrtz_fired_trigger_pk primary key (sched_name,entry_id) + sched_name varchar2(120) not null, + entry_id varchar2(95) not null, + trigger_name varchar2(200) not null, + trigger_group varchar2(200) not null, + instance_name varchar2(200) not null, + fired_time number(13) not null, + sched_time number(13) not null, + priority number(13) not null, + state varchar2(16) not null, + job_name varchar2(200) null, + job_group varchar2(200) null, + is_nonconcurrent varchar2(1) null, + requests_recovery varchar2(1) null, + constraint qrtz_fired_trigger_pk primary key (sched_name, entry_id) ); +comment on table qrtz_fired_triggers is '已触发的触发器表'; +comment on column qrtz_fired_triggers.sched_name is '调度名称'; +comment on column qrtz_fired_triggers.entry_id is '调度器实例id'; +comment on column qrtz_fired_triggers.trigger_name is 'qrtz_triggers表trigger_name的外键'; +comment on column qrtz_fired_triggers.trigger_group is 'qrtz_triggers表trigger_group的外键'; +comment on column qrtz_fired_triggers.instance_name is '调度器实例名'; +comment on column qrtz_fired_triggers.fired_time is '触发的时间'; +comment on column qrtz_fired_triggers.sched_time is '定时器制定的时间'; +comment on column qrtz_fired_triggers.priority is '优先级'; +comment on column qrtz_fired_triggers.state is '状态'; +comment on column qrtz_fired_triggers.job_name is '任务名称'; +comment on column qrtz_fired_triggers.job_group is '任务组名'; +comment on column qrtz_fired_triggers.is_nonconcurrent is '是否并发'; +comment on column qrtz_fired_triggers.requests_recovery is '是否接受恢复执行'; + -- ---------------------------- -- 9、 存储少量的有关 Scheduler 的状态信息,假如是用于集群中,可以看到其他的 Scheduler 实例 -- ---------------------------- create table qrtz_scheduler_state ( - sched_name varchar2(120) not null, - instance_name varchar2(200) not null, - last_checkin_time number(13) not null, - checkin_interval number(13) not null, - constraint qrtz_scheduler_state_pk primary key (sched_name,instance_name) + sched_name varchar2(120) not null, + instance_name varchar2(200) not null, + last_checkin_time number(13) not null, + checkin_interval number(13) not null, + constraint qrtz_scheduler_state_pk primary key (sched_name, instance_name) ); +comment on table qrtz_scheduler_state is '调度器状态表'; +comment on column qrtz_scheduler_state.sched_name is '调度名称'; +comment on column qrtz_scheduler_state.instance_name is '实例名称'; +comment on column qrtz_scheduler_state.last_checkin_time is '上次检查时间'; +comment on column qrtz_scheduler_state.checkin_interval is '检查间隔时间'; + -- ---------------------------- -- 10、 存储程序的悲观锁的信息(假如使用了悲观锁) -- ---------------------------- create table qrtz_locks ( - sched_name varchar2(120) not null, - lock_name varchar2(40) not null, - constraint qrtz_locks_pk primary key (sched_name,lock_name) + sched_name varchar2(120) not null, + lock_name varchar2(40) not null, + constraint qrtz_locks_pk primary key (sched_name, lock_name) ); +comment on table qrtz_locks is '存储的悲观锁信息表'; +comment on column qrtz_locks.sched_name is '调度名称'; +comment on column qrtz_locks.lock_name is '悲观锁名称'; + +-- ---------------------------- +-- 11、 Quartz集群实现同步机制的行锁表 +-- ---------------------------- create table qrtz_simprop_triggers ( - sched_name varchar2(120) not null, - trigger_name varchar2(200) not null, - trigger_group varchar2(200) not null, - str_prop_1 varchar2(512) null, - str_prop_2 varchar2(512) null, - str_prop_3 varchar2(512) null, - int_prop_1 number(10) null, - int_prop_2 number(10) null, - long_prop_1 number(13) null, - long_prop_2 number(13) null, - dec_prop_1 numeric(13,4) null, - dec_prop_2 numeric(13,4) null, - bool_prop_1 varchar2(1) null, - bool_prop_2 varchar2(1) null, - constraint qrtz_simprop_trig_pk primary key (sched_name,trigger_name,trigger_group), - constraint qrtz_simprop_trig_to_trig_fk foreign key (sched_name,trigger_name,trigger_group) - references qrtz_triggers(sched_name,trigger_name,trigger_group) + sched_name varchar2(120) not null, + trigger_name varchar2(200) not null, + trigger_group varchar2(200) not null, + str_prop_1 varchar2(512) null, + str_prop_2 varchar2(512) null, + str_prop_3 varchar2(512) null, + int_prop_1 number(10) null, + int_prop_2 number(10) null, + long_prop_1 number(13) null, + long_prop_2 number(13) null, + dec_prop_1 numeric(13,4) null, + dec_prop_2 numeric(13,4) null, + bool_prop_1 varchar2(1) null, + bool_prop_2 varchar2(1) null, + constraint qrtz_simprop_trig_pk primary key (sched_name, trigger_name, trigger_group), + constraint qrtz_simprop_trig_to_trig_fk foreign key (sched_name, trigger_name, trigger_group) references qrtz_triggers(sched_name, trigger_name, trigger_group) ); +comment on table qrtz_simprop_triggers is '同步机制的行锁表'; +comment on column qrtz_simprop_triggers.sched_name is '调度名称'; +comment on column qrtz_simprop_triggers.trigger_name is 'qrtz_triggers表trigger_name的外键'; +comment on column qrtz_simprop_triggers.trigger_group is 'qrtz_triggers表trigger_group的外键'; +comment on column qrtz_simprop_triggers.str_prop_1 is 'String类型的trigger的第一个参数'; +comment on column qrtz_simprop_triggers.str_prop_2 is 'String类型的trigger的第二个参数'; +comment on column qrtz_simprop_triggers.str_prop_3 is 'String类型的trigger的第三个参数'; +comment on column qrtz_simprop_triggers.int_prop_1 is 'int类型的trigger的第一个参数'; +comment on column qrtz_simprop_triggers.int_prop_2 is 'int类型的trigger的第二个参数'; +comment on column qrtz_simprop_triggers.long_prop_1 is 'long类型的trigger的第一个参数'; +comment on column qrtz_simprop_triggers.long_prop_2 is 'long类型的trigger的第二个参数'; +comment on column qrtz_simprop_triggers.dec_prop_1 is 'decimal类型的trigger的第一个参数'; +comment on column qrtz_simprop_triggers.dec_prop_2 is 'decimal类型的trigger的第二个参数'; +comment on column qrtz_simprop_triggers.bool_prop_1 is 'Boolean类型的trigger的第一个参数'; +comment on column qrtz_simprop_triggers.bool_prop_2 is 'Boolean类型的trigger的第二个参数'; -create index idx_qrtz_j_req_recovery on qrtz_job_details(sched_name,requests_recovery); -create index idx_qrtz_j_grp on qrtz_job_details(sched_name,job_group); +create index idx_qrtz_j_req_recovery on qrtz_job_details(sched_name, requests_recovery); +create index idx_qrtz_j_grp on qrtz_job_details(sched_name, job_group); -create index idx_qrtz_t_j on qrtz_triggers(sched_name,job_name,job_group); -create index idx_qrtz_t_jg on qrtz_triggers(sched_name,job_group); -create index idx_qrtz_t_c on qrtz_triggers(sched_name,calendar_name); -create index idx_qrtz_t_g on qrtz_triggers(sched_name,trigger_group); -create index idx_qrtz_t_state on qrtz_triggers(sched_name,trigger_state); -create index idx_qrtz_t_n_state on qrtz_triggers(sched_name,trigger_name,trigger_group,trigger_state); -create index idx_qrtz_t_n_g_state on qrtz_triggers(sched_name,trigger_group,trigger_state); -create index idx_qrtz_t_next_fire_time on qrtz_triggers(sched_name,next_fire_time); -create index idx_qrtz_t_nft_st on qrtz_triggers(sched_name,trigger_state,next_fire_time); -create index idx_qrtz_t_nft_misfire on qrtz_triggers(sched_name,misfire_instr,next_fire_time); -create index idx_qrtz_t_nft_st_misfire on qrtz_triggers(sched_name,misfire_instr,next_fire_time,trigger_state); -create index idx_qrtz_t_nft_st_misfire_grp on qrtz_triggers(sched_name,misfire_instr,next_fire_time,trigger_group,trigger_state); +create index idx_qrtz_t_j on qrtz_triggers(sched_name, job_name, job_group); +create index idx_qrtz_t_jg on qrtz_triggers(sched_name, job_group); +create index idx_qrtz_t_c on qrtz_triggers(sched_name, calendar_name); +create index idx_qrtz_t_g on qrtz_triggers(sched_name, trigger_group); +create index idx_qrtz_t_state on qrtz_triggers(sched_name, trigger_state); +create index idx_qrtz_t_n_state on qrtz_triggers(sched_name, trigger_name, trigger_group, trigger_state); +create index idx_qrtz_t_n_g_state on qrtz_triggers(sched_name, trigger_group, trigger_state); +create index idx_qrtz_t_next_fire_time on qrtz_triggers(sched_name, next_fire_time); +create index idx_qrtz_t_nft_st on qrtz_triggers(sched_name, trigger_state, next_fire_time); +create index idx_qrtz_t_nft_misfire on qrtz_triggers(sched_name, misfire_instr, next_fire_time); +create index idx_qrtz_t_nft_st_misfire on qrtz_triggers(sched_name, misfire_instr, next_fire_time, trigger_state); +create index idx_qrtz_t_nft_st_misfire_grp on qrtz_triggers(sched_name, misfire_instr, next_fire_time, trigger_group, trigger_state); -create index idx_qrtz_ft_trig_inst_name on qrtz_fired_triggers(sched_name,instance_name); -create index idx_qrtz_ft_inst_job_req_rcvry on qrtz_fired_triggers(sched_name,instance_name,requests_recovery); -create index idx_qrtz_ft_j_g on qrtz_fired_triggers(sched_name,job_name,job_group); -create index idx_qrtz_ft_jg on qrtz_fired_triggers(sched_name,job_group); -create index idx_qrtz_ft_t_g on qrtz_fired_triggers(sched_name,trigger_name,trigger_group); +create index idx_qrtz_ft_trig_inst_name on qrtz_fired_triggers(sched_name, instance_name); +create index idx_qrtz_ft_inst_job_req_rcvry on qrtz_fired_triggers(sched_name, instance_name, requests_recovery); +create index idx_qrtz_ft_j_g on qrtz_fired_triggers(sched_name, job_name, job_group); +create index idx_qrtz_ft_jg on qrtz_fired_triggers(sched_name, job_group); +create index idx_qrtz_ft_t_g on qrtz_fired_triggers(sched_name, trigger_name, trigger_group); -create index idx_qrtz_ft_tg on qrtz_fired_triggers(sched_name,trigger_group); +create index idx_qrtz_ft_tg on qrtz_fired_triggers(sched_name, trigger_group); commit; \ No newline at end of file diff --git a/src/main/java/com/ruoyi/framework/config/ScheduleConfig.java b/src/main/java/com/ruoyi/framework/config/ScheduleConfig.java index 14024bf..50e11d3 100644 --- a/src/main/java/com/ruoyi/framework/config/ScheduleConfig.java +++ b/src/main/java/com/ruoyi/framework/config/ScheduleConfig.java @@ -1,57 +1,57 @@ -//package com.ruoyi.framework.config; -// -//import org.springframework.context.annotation.Bean; -//import org.springframework.context.annotation.Configuration; -//import org.springframework.scheduling.quartz.SchedulerFactoryBean; -//import javax.sql.DataSource; -//import java.util.Properties; -// -///** -// * 定时任务配置 -// * -// * @author ruoyi -// */ -//@Configuration -//public class ScheduleConfig -//{ -// @Bean -// public SchedulerFactoryBean schedulerFactoryBean(DataSource dataSource) -// { -// SchedulerFactoryBean factory = new SchedulerFactoryBean(); -// factory.setDataSource(dataSource); -// -// // quartz参数 -// Properties prop = new Properties(); -// prop.put("org.quartz.scheduler.instanceName", "RuoyiScheduler"); -// prop.put("org.quartz.scheduler.instanceId", "AUTO"); -// // 线程池配置 -// prop.put("org.quartz.threadPool.class", "org.quartz.simpl.SimpleThreadPool"); -// prop.put("org.quartz.threadPool.threadCount", "20"); -// prop.put("org.quartz.threadPool.threadPriority", "5"); -// // JobStore配置 -// prop.put("org.quartz.jobStore.class", "org.quartz.impl.jdbcjobstore.JobStoreTX"); -// // 集群配置 -// prop.put("org.quartz.jobStore.isClustered", "true"); -// prop.put("org.quartz.jobStore.clusterCheckinInterval", "15000"); -// prop.put("org.quartz.jobStore.maxMisfiresToHandleAtATime", "1"); -// prop.put("org.quartz.jobStore.txIsolationLevelSerializable", "false"); -// -// // sqlserver 启用 -// // prop.put("org.quartz.jobStore.selectWithLockSQL", "SELECT * FROM {0}LOCKS UPDLOCK WHERE LOCK_NAME = ?"); -// prop.put("org.quartz.jobStore.misfireThreshold", "12000"); -// prop.put("org.quartz.jobStore.tablePrefix", "QRTZ_"); -// factory.setQuartzProperties(prop); -// -// factory.setSchedulerName("RuoyiScheduler"); -// // 延时启动 -// factory.setStartupDelay(1); -// factory.setApplicationContextSchedulerContextKey("applicationContextKey"); -// // 可选,QuartzScheduler -// // 启动时更新己存在的Job,这样就不用每次修改targetObject后删除qrtz_job_details表对应记录了 -// factory.setOverwriteExistingJobs(true); -// // 设置自动启动,默认为true -// factory.setAutoStartup(true); -// -// return factory; -// } -//} +package com.ruoyi.framework.config; + +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.scheduling.quartz.SchedulerFactoryBean; +import javax.sql.DataSource; +import java.util.Properties; + +/** + * 定时任务配置 + * + * @author ruoyi + */ +@Configuration +public class ScheduleConfig +{ + @Bean + public SchedulerFactoryBean schedulerFactoryBean(DataSource dataSource) + { + SchedulerFactoryBean factory = new SchedulerFactoryBean(); + factory.setDataSource(dataSource); + + // quartz参数 + Properties prop = new Properties(); + prop.put("org.quartz.scheduler.instanceName", "RuoyiScheduler"); + prop.put("org.quartz.scheduler.instanceId", "AUTO"); + // 线程池配置 + prop.put("org.quartz.threadPool.class", "org.quartz.simpl.SimpleThreadPool"); + prop.put("org.quartz.threadPool.threadCount", "20"); + prop.put("org.quartz.threadPool.threadPriority", "5"); + // JobStore配置 + prop.put("org.quartz.jobStore.class", "org.quartz.impl.jdbcjobstore.JobStoreTX"); + // 集群配置 + prop.put("org.quartz.jobStore.isClustered", "true"); + prop.put("org.quartz.jobStore.clusterCheckinInterval", "15000"); + prop.put("org.quartz.jobStore.maxMisfiresToHandleAtATime", "1"); + prop.put("org.quartz.jobStore.txIsolationLevelSerializable", "false"); + + // sqlserver 启用 + // prop.put("org.quartz.jobStore.selectWithLockSQL", "SELECT * FROM {0}LOCKS UPDLOCK WHERE LOCK_NAME = ?"); + prop.put("org.quartz.jobStore.misfireThreshold", "12000"); + prop.put("org.quartz.jobStore.tablePrefix", "QRTZ_"); + factory.setQuartzProperties(prop); + + factory.setSchedulerName("RuoyiScheduler"); + // 延时启动 + factory.setStartupDelay(1); + factory.setApplicationContextSchedulerContextKey("applicationContextKey"); + // 可选,QuartzScheduler + // 启动时更新己存在的Job,这样就不用每次修改targetObject后删除qrtz_job_details表对应记录了 + factory.setOverwriteExistingJobs(true); + // 设置自动启动,默认为true + factory.setAutoStartup(true); + + return factory; + } +}