一、问题描述
使用Quartz配置定时任务,配置了超过10个定时任务,这些定时任务配置的触发时间都是5分钟执行一次,实际运行时,发现总有几个定时任务不能执行到。
二、示例程序
1、简单介绍
采用spring+quartz整合方案实现定时任务,Quartz的SchedulerFactoryBean配置参数中不注入taskExecutor属性,使用默认自带的线程池。准备了15个定时任务,全部设置为每隔10秒触发一次,定时任务的实现逻辑是使用休眠8秒的方式模拟执行定时任务的时间耗费。
2、配置文件信息如下(节选):
<bean id="startQuertz" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="testMethod1Trigger"/>
<ref bean="testMethod2Trigger"/>
// 以下省略13个 触发器的配置
</list>
</property>
</bean>
<bean id="testMethod1Trigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
<property name="jobDetail" ref="testMethod1" />
<!-- 指定Cron表达式:每10秒触发一次 -->
<property name="cronExpression" value="0/10 * * * * ?"/>
</bean>
<bean id="testMethod1" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="triggerService" />
<!-- 要执行的方法名称 -->
<property name="targetMethod" value="method1" />
</bean>
// 以下省略14个定时任务的配置
3、Java定时任务类程序如下(节选)
@Service("triggerService")
public<

本文分析了Quartz框架在配置多个定时任务时,由于线程池大小限制导致某些任务漏执行的现象。通过源码解析,揭示了任务过期作废的机制。解决方案包括增加线程池资源和错峰触发任务。
最低0.47元/天 解锁文章
2448

被折叠的 条评论
为什么被折叠?



