最近在项目开发中进行了一些Spring定时任务的开发工作,在开发过程中对Spring定时任务的配置方式进行了一些研究,现在对各种配置方式进行一个总结。Scheduled是Spring支持的定时任务配置方式,可以用注解或者配置文件的方式进行配置。
Quartz是一个强大的企业级任务调度框架,Spring中继承并简化了Quartz,它是一个开源的由OpenSymphony维护的项目,开发者能够在Java EE,或单独的Java SE应用中使用它。无论是简单的任务调度,还是复杂的企业级应用,Quartz都能够很好地胜任。
Quartz支持CronTriggerBean,SimpleTriggerBean两种模式,CronTriggerBean比 SimpleTriggerBean功能更强大,它能够控制任务执行的精确时间,比如,早上九点半需要执行某QuartzJobBean中给定的任务。
以下对不同的配置方式分别进行介绍。
<task:scheduled-tasks scheduler="scheduler" >
<task:scheduled ref="profitScheduler" method="execute" cron="0 0/2 * * * ?" initial-delay="5000" fixed-delay="3600000" />
</task:scheduled-tasks>
<task:scheduler id="scheduler" pool-size="5" />
也可以采用注解的方式,在需要配置为定时任务的方法上添加@Scheduled(cron = "0 0 3 * * ?"),cron为定时任务表达式,cron表达式支持非常丰富的配置规则。
@Component(“taskJob”)
public class TaskJob { k
@Scheduled(cron = "0 0 3 * * ?")
public void job1() {
System.out.println(“任务进行中。。。”);
}
}
配置任务执行的线程池信息。task:scheduler用来配置任务调度线程池大小,调度线程在被调度任务完成前不会空闲;task:executor用来配置任务执行器的具体参数,pool-size 可以指定执行线程池的初始大小、最大大小,queue-capacity配置等待执行任务的队列容量,reject-policy当等待队列爆了时的策略,分为丢弃、有任务执行器直接执行等方式。
<task:executor id="executor" pool-size="10-10000" queue-capacity="5000" rejection-policy="CALLER_RUNS"/>
<task:scheduler id="scheduler" pool-size="1000"/>
<task:annotation-driven executor="executor" scheduler="scheduler"/>
CronTrigger 支持比simpleTrigger更具体的调度,CronTrigger支持类似日历的重复间隔。CronTrigger 由MethodInvokingJobDetailFactoryBean、CronTriggerFactoryBean两个类支持。
MethodInvokingJobDetailFactoryBean配置需要定时执行的任务类和方法,targetObject为执行定时任务的bean,targetMethod为执行定时任务的bean中的方法。CronTriggerFactoryBean为定时任务的触发器,用来配置定时任务执行的时间表达式。
<bean id="sycnMonitorBean" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="monitorService" />
<property name="targetMethod" value="syncMonitor" />
</bean>
<bean id="syncTrigger"
class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
<property name="jobDetail" ref="sycnMonitorBean" />
<property name="cronExpression" value="0 */10 * * * ?" />
</bean>
<bean id="quartzBean" class="com.abchina.tao.scheduled.QuartzMain">
<property name="scheduler" ref="schedulerManager"></property>
</bean>
<!-- 定义jobdetail -->
<bean id="quartzJobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="quartzBean"></property>
<property name="targetMethod" value="startQuartz"></property>
<property name="concurrent" value="false" />
</bean>
<bean id="quartzTrigger"
class="org.springframework.scheduling.quartz.SimpleTriggerFactoryBean">
<property name="jobDetail" ref="quartzJobDetail"></property>
<property name="startDelay" value="1000"></property>
<property name="repeatInterval" value="300000"></property>
</bean>
<!-- 任务计划,总管理类-->
<bean id="schedulerManager" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="quartzTrigger" />
</list>
</property>
</bean>
MethodInvokingJobDetailFactoryBean mijdfb=new MethodInvokingJobDetailFactoryBean();
mijdfb.setName(qm.getEnvId());
mijdfb.setTargetObject(beanFactory.getBean("service",Mservice.class));
mijdfb.setTargetMethod("runTask");
mijdfb.setConcurrent(false);
TestEnvDomain [] params = new TestEnvDomain[1];
params[0] = qm;
mijdfb.setArguments(params);
mijdfb.afterPropertiesSet();
org.quartz.JobDetail jd=new JobDetailImpl();
jd=mijdfb.getObject();
scheduler.addJob(jd, true);
(2)实例化触发器
String triggerName=qm.getEnvId() +"Trigger";
CronTriggerFactoryBean ctb=new CronTriggerFactoryBean();
ctb.setName(triggerName);
ctb.setCronExpression(qm.getCronExpression());
ctb.setJobDetail(jd);
ctb.afterPropertiesSet();
CronTrigger cronTrigger= ctb.getObject();
scheduler.scheduleJob(cronTrigger);
scheduler.rescheduleJob(cronTrigger.getKey(), cronTrigger);
热 文 推 荐
☞斯坦福博士退学,在 3 个领域改变世界,科技狂人马斯克的巅峰之路