【源码系列-6】quartz源码学习

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。

猜你喜欢

转载自blog.csdn.net/u010659877/article/details/106670235