quartz分布式任务管理
可以分布式的部署多个节点,quartz调度不同的节点做不同的事情
配置job方式
quartz支持两种方式配置job,MethodInvokingJobDetailFactoryBean和JobDetailFactoryBean,其中JobDetailFactoryBean可以通过datamap传递参数。
配置触发器方式
触发器通过两种方式配置,SimpleTriggerFactoryBean和CronTriggerFactoryBean,后者通过cron表达式配置出发逻辑
分布式调度实现方式
调度器可以通过内存或者数据库,通过配置数据库信息的方式可以实现job的分布式调度和运行
数据库表的内容:
qrtz_blob_triggers:自定义的triggers信息
qrtz_cron_triggers:存储cron trigger
qrtz_simple_triggers:存储普通的trigger
qrtz_simprop_triggers:存储calendar interval触发器
qrtz_fired_triggers:存储已经触发的触发器
qrtz_job_details:定义job内容
qrtz_calendars:定义一个时间段,可以控制触发器在这个时间段内触发或者不触发
qrtz_paused_trigger_grps: 存放暂停的触发器
qrtz_scheduler_state:存储所有结点的scheduler,检查是否失效
qrtz_locks:分布式锁表
java源码
quartz的核心调度类是QuartzSchedulerThread,他的基类是Thread。通过ThreadPool来执行封装job的JobRunShell。