【源码系列-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。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值