资料地址:https://www.w3cschool.cn/quartz_doc/
手机上查看文档:https://m.w3cschool.cn/quartz_doc/
Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目。
Quartz 是一个完全由 Java 编写的开源作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制。
Quartz 可以与 J2EE 与 J2SE 应用程序相结合也可以单独使用。
Quartz 允许程序开发人员根据时间的间隔来调度作业。
Quartz 实现了作业和触发器的多对多的关系,还能把多个作业与不同的触发器关联。
我们需要明白 Quartz 的几个核心概念,这样理解起 Quartz 的原理就会变得简单了。
Job 表示一个工作,要执行的具体内容。此接口中只有一个方法,如下: void execute(JobExecutionContext context) JobDetail 表示一个具体的可执行的调度程序,Job 是这个可执行程调度程序所要执行的内容,另外 JobDetail 还包含了这个任务调度的方案和策略。Trigger 代表一个调度参数的配置,什么时候去调。Scheduler 代表一个调度容器,一个调度容器中可以注册多个 JobDetail 和 Trigger。当 Trigger 与 JobDetail 组合,就可以被 Scheduler 容器调度了。《Java教程》
《Java面试问题 》
《Javascript教程》
http://www.quartz-scheduler.org/documentation/quartz-2.2.x/quick-start.html
莫非的老公关注
2019.03.21 11:47:59字数 285阅读 1,103
1. qrtz_job_details:存储每一个已配置的 jobDetail 的详细信息
表字段含义sched_name调度名称job_name集群中job的名字,该名字用户自己可以随意定制,无强行要求job_group集群中job的所属组的名字,该名字用户自己随意定制,无强行要求description相关介绍job_class_name集群中个notejob实现类的完全包名,quartz就是根据这个路径到classpath找到该job类is_durable是否持久化,把该属性设置为1,quartz会把job持久化到数据库中is_nonconcurrent是否并发is_update_data是否更新数据requests_recovery是否接受恢复执行,默认为false,设置了RequestsRecovery为true,则该job会被重新执行job_data一个blob字段,存放持久化job对象2. qrtz_triggers: 保存触发器的基本信息
表字段含义sched_name调度名称trigger_name触发器的名字,该名字用户自己可以随意定制,无强行要求trigger_group触发器所属组的名字,该名字用户自己随意定制,无强行要求job_nameqrtz_job_details表job_name的外键job_groupqrtz_job_details表job_group的外键description相关介绍next_fire_time上一次触发时间(毫秒)prev_fire_time下一次触发时间,默认为-1,意味不会自动触发priority优先级trigger_state当前触发器状态,设置为ACQUIRED,如果设置为WAITING,则job不会触发 ( WAITING:等待 PAUSED:暂停ACQUIRED:正常执行 BLOCKED:阻塞 ERROR:错误)trigger_type触发器的类型,使用cron表达式start_time开始时间end_time结束时间calendar_name日程表名称,表qrtz_calendars的calendar_name字段外键misfire_instr措施或者是补偿执行的策略job_data一个blob字段,存放持久化job对象3. qrtz_cron_triggers:存储触发器的cron表达式表。
表字段含义sched_name调度名称trigger_nameqrtz_triggers表trigger_name的外键trigger_groupqrtz_triggers表trigger_group的外键cron_expressioncron表达式time_zone_id时区4. qrtz_scheduler_state:存储集群中note实例信息,quartz会定时读取该表的信息判断集群中每个实例的当前状态。
表字段含义sched_name调度名称instance_name之前配置文件中org.quartz.scheduler.instanceId配置的名字,就会写入该字段last_checkin_time上次检查时间checkin_interval检查间隔时间5. qrtz_blob_triggers:Trigger 作为 Blob 类型存储(用于 Quartz 用户用 JDBC 创建他们自己定制的 Trigger 类型,JobStore 并不知道如何存储实例的时候)
表字段含义sched_name调度名称trigger_nameqrtz_triggers表trigger_name的外键trigger_groupqrtz_triggers表trigger_group的外键blob_data一个blob字段,存放持久化Trigger对象6. qrtz_calendars:以 Blob 类型存储存放日历信息, quartz可配置一个日历来指定一个时间范围。
表字段含义sched_name调度名称calendar_name日历名称calendar一个blob字段,存放持久化calendar对象7. qrtz_fired_triggers:存储与已触发的 Trigger 相关的状态信息,以及相联 Job 的执行信息。
表字段含义sched_name调度名称entry_id调度器实例idtrigger_nameqrtz_triggers表trigger_name的外键trigger_groupqrtz_triggers表trigger_group的外键instance_name调度器实例名fired_time触发的时间sched_time定时器制定的时间priority优先级state状态job_name集群中job的名字,该名字用户自己可以随意定制,无强行要求job_group集群中job的所属组的名字,该名字用户自己随意定制,无强行要求is_nonconcurrent是否并发requests_recovery是否接受恢复执行,默认为false,设置了RequestsRecovery为true,则会被重新执行8. qrtz_locks:存储程序的悲观锁的信息(假如使用了悲观锁)。
表字段含义sched_name调度名称lock_name悲观锁名称9. qrtz_paused_trigger_grps:存储已暂停的 Trigger 组的信息。
表字段含义sched_name调度名称trigger_groupqrtz_triggers表trigger_group的外键10. qrtz_paused_trigger_grps:存储已暂停的 Trigger 组的信息。
表字段含义sched_name调度名称trigger_groupqrtz_triggers表trigger_group的外键11. qrtz_simple_triggers:存储简单的 Trigger,包括重复次数,间隔,以及已触发的次数。
表字段含义sched_name调度名称trigger_nameqrtz_triggers表trigger_ name的外键trigger_groupqrtz_triggers表trigger_group的外键repeat_count重复的次数统计repeat_interval重复的间隔时间times_triggered已经触发的次数12. qrtz_simprop_triggers:存储CalendarIntervalTrigger和DailyTimeIntervalTrigger
表字段含义SCHED_NAME调度名称TRIGGER_NAMEqrtz_triggers表trigger_ name的外键TRIGGER_GROUPqrtz_triggers表trigger_group的外键STR_PROP_1String类型的trigger的第一个参数STR_PROP_2String类型的trigger的第二个参数STR_PROP_3String类型的trigger的第三个参数INT_PROP_1int类型的trigger的第一个参数INT_PROP_2int类型的trigger的第二个参数LONG_PROP_1long类型的trigger的第一个参数LONG_PROP_2long类型的trigger的第二个参数DEC_PROP_1decimal类型的trigger的第一个参数DEC_PROP_2decimal类型的trigger的第二个参数BOOL_PROP_1Boolean类型的trigger的第一个参数BOOL_PROP_2Boolean类型的trigger的第二个参数
0人点赞
QRTZ_CALENDARS 以 Blob 类型存储 Quartz 的 Calendar 信息
QRTZ_CRON_TRIGGERS 存储 Cron Trigger,包括 Cron表达式和时区信息
QRTZ_FIRED_TRIGGERS 存储与已触发的 Trigger 相关的状态信息,以及相联 Job的执行信息 QRTZ_PAUSED_TRIGGER_GRPS 存储已暂停的 Trigger 组的信息
QRTZ_SCHEDULER_STATE 存储少量的有关 Scheduler 的状态信息,和别的 Scheduler实例(假如是用于一个集群中)
QRTZ_LOCKS 存储程序的悲观锁的信息(假如使用了悲观锁)
QRTZ_JOB_DETAILS 存储每一个已配置的 Job 的详细信息
QRTZ_JOB_LISTENERS 存储有关已配置的 JobListener 的信息
QRTZ_SIMPLE_TRIGGERS 存储简单的Trigger,包括重复次数,间隔,以及已触的次数
QRTZ_BLOG_TRIGGERS Trigger 作为 Blob 类型存储(用于 Quartz 用户用 JDBC创建他们自己定制的 Trigger 类型,JobStore 并不知道如何存储实例的时候)
QRTZ_TRIGGER_LISTENERS 存储已配置的 TriggerListener 的信息
QRTZ_TRIGGERS 存储已配置的 Trigger 的信息
建表,SQL语句在quartz-1.6.6\docs\dbTables文件夹中可以找到,介绍下主要的几张表: 表qrtz_job_details: 保存job详细信息,该表需要用户根据实际情况初始化 job_name:集群中job的名字,该名字用户自己可以随意定制,无强行要求 job_group:集群中job的所属组的名字,该名字用户自己随意定制,无强行要求 job_class_name:集群中个note job实现类的完全包名,quartz就是根据这个路径到classpath找到该job类 is_durable:是否持久化,把该属性设置为1,quartz会把job持久化到数据库中 job_data:一个blob字段,存放持久化job对象 表qrtz_triggers: 保存trigger信息 trigger_name: trigger的名字,该名字用户自己可以随意定制,无强行要求 trigger_group:trigger所属组的名字,该名字用户自己随意定制,无强行要求 job_name: qrtz_job_details表job_name的外键 job_group: qrtz_job_details表job_group的外键 trigger_state:当前trigger状态,设置为ACQUIRED,如果设置为WAITING,则job不会触发 trigger_cron:触发器类型,使用cron表达式 表qrtz_cron_triggers:存储cron表达式表 trigger_name: qrtz_triggers表trigger_name的外键 trigger_group: qrtz_triggers表trigger_group的外键 cron_expression:cron表达式 表qrtz_scheduler_state:存储集群中note实例信息,quartz会定时读取该表的信息判断集群中每个实例的当前状态 instance_name:之前配置文件中org.quartz.scheduler.instanceId配置的名字,就会写入该字段,如果设置为AUTO,quartz会根据物理机名和当前时间产生一个名字 last_checkin_time:上次检查时间 checkin_interval:检查间隔时间
#调度标识名 集群中每一个实例都必须使用相同的名称 org.quartz.scheduler.instanceName = scheduler
#ID设置为自动获取 每一个必须不同 org.quartz.scheduler.instanceId = AUTO
#数据保存方式为持久化 org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
#数据库平台 org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.oracle.weblogic.WebLogicOracleDelegate #数据库别名 随便取org.quartz.jobStore.dataSource = myXADS
#表的前缀 org.quartz.jobStore.tablePrefix = QRTZ_
#设置为TRUE不会出现序列化非字符串类到 BLOB 时产生的类版本问题 org.quartz.jobStore.useProperties = true
#加入集群 org.quartz.jobStore.isClustered = true
#调度实例失效的检查时间间隔 org.quartz.jobStore.clusterCheckinInterval = 20000
#容许的最大作业延长时间 org.quartz.jobStore.misfireThreshold = 60000
#ThreadPool 实现的类名 org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
#线程数量 org.quartz.threadPool.threadCount = 10
#线程优先级 org.quartz.threadPool.threadPriority = 5
#自创建父线程 org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true
#设置数据源org.quartz.dataSource.myXADS.jndiURL = CT
#jbdi类名 org.quartz.dataSource.myXADS.java.naming.factory.initial = weblogic.jndi.WLInitialContextFactory #URLorg.quartz.dataSource.myXADS.java.naming.provider.url = t3://localhost:7001
注】:在J2EE工程中如果想用数据库管理Quartz的相关信息,就一定要配置数据源,这是Quartz的要求。