[译]如何优化Quartz调度器性能

本文翻译自'Performance Tuning on Quartz Scheduler',探讨了Quartz在高负载下遇到的问题,如触发器失效和数据库锁竞争,并通过复现问题、分析原因,提出通过批量模式和调整作业数据更新顺序来优化性能,减少了触发器堆积和锁等待时间,显著提升了执行效率。
摘要由CSDN通过智能技术生成

译文由杰微刊兼职译者刘晓冬翻译,杰微刊审校及发布。

 

Quartz是一个流行的Java应用开源作业调度库。eBay在自己的很多项目中用它来调度作业。


Quartz在低负载时运行良好,但在高负载时会遇到问题。许多触发器会失效,导致执行线程无法得到任务,大量作业阻塞在触发器表中。


所以我们必须进行性能调优。本章描述我们是如何逐步解决问题并优化Quartz的。

 

问题在哪?
1.Quartz作业不能被调度和执行。


2.许多作业在simple_triggers表中等待执行,但一些作业在fired_triggers中。这些简单触发器应当设置REPEAT_INTERVAL,表明它们是重复作业。


TIMES_TRIGGERED表示该作业被触发的次数


Quartz,调优

 

3.日志文件中有大量的“Handling the first 20 triggers that missed their scheduled fire-time …”(处理错过调度触发时间点的前20个触发器)
 

Quartz,调优


4.数据库session增加,许多session等待在“SELECT * FROM qrtz_LOCKS WHERE SCHED_NAME = ‘{SCHED_NAME}‘ AND LOCK_NAME = ‘TRIGGER_ACCESS’ FOR UPDATE”。

 

什么是触发器失效?
在我们能理解为什么发生之前,先来看看触发器失效。这是来自Quartz官方网站的解释:


 触发器失效发生在一致性触发器,因为调度器关闭而错过触发时间点&#

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值