补充定时任务表字段注释

This commit is contained in:
RuoYi 2021-08-20 15:17:09 +08:00
parent 34157bbbe0
commit f8eb59e9d1
2 changed files with 301 additions and 177 deletions

View File

@ -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;

View File

@ -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;
}
}