demo简介:
这是个简单quartz实例,主要quart配置集成spring,功能为每20秒输出一句内容!
运行效果如下:
[31:20] - Starting Quartz Scheduler now, after delay of 20 seconds
[31:20] - Scheduler demoTimer_$_NON_CLUSTERED started.
[31:21] - dddd
日志输出
定时任务测试
[32:00] - dddd
日志输出
定时任务测试
[33:00] - dddd
日志输出
定时任务测试
[34:00] - dddd
日志输出
定时任务测试
[35:00] - dddd
demo实例类:testJob.class 用来做定时任务测试的测试类
package com.ake.dccs.ecs.job;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class testJob {
private static final Logger LOGGER= LoggerFactory.getLogger(testJob.class);
public void doTask(){
LOGGER.info("dddd");
System.out.println("日志输出");
System.out.println("定时任务测试");
}
}
集成Spring配置:
<!-- 定时服务 -->
<!--注册定时器-->
<bean id="demoTimer" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<!--必须配置quartz延迟启动,在应用启动后起动,延迟20秒-->
<property name="startupDelay" value="20"/>
<!--普通触发器,触发器列表-->
<property name="triggers">
<list>
<ref bean="taskDemoTrigger"/>
</list>
</property>
</bean>
<!--CronTrigger配置-->
<bean id="taskDemoTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
<!--定时任务详细方法类-->
<property name="jobDetail" ref="taskDemoJobDetail"/>
<!--cron表达式-->
<property name="cronExpression">
<value>0/60 * * ? * *</value> <!-- 间隔时间60s -->
</property>
</bean>
<!--制定定时任务细节 调用哪个类 哪个方法-->
<bean id="taskDemoJobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject">
<ref bean="taskDemo"/>
</property>
<property name="targetMethod">
<value>doTask</value>
</property>
<property name="concurrent" value="false"/>
</bean>
<!--定时任务的类-->
<bean id="taskDemo" class="com.ake.dccs.ecs.job.testJob"/>
<!--扫描项目包-->
<context:component-scan base-package="com.ake.dccs.ecs.job"/>
</beans>
pom.xml写入依赖
<!-- quartz 定时服务 -->
<dependency>
<groupId>org.quartz-scheduler</groupId>
<artifactId>quartz</artifactId>
<version>2.2.1</version>
</dependency>
<dependency>
<groupId>org.quartz-scheduler</groupId>
<artifactId>quartz-jobs</artifactId>
<version>2.2.1</version>
</dependency>
注意事项:
1.
如果配置文件applicationContext-scheduler.xml和applicationContext.xml不耦合,必须将其配置到applicationContext.xml里,才能进行扫描。
例子:
<!-- 导入分割的spring配置文件 -->
<import resource="applicationContext-beans.xml"/>
<import resource="applicationContext-datasource.xml"/>
<import resource="applicationContext-cache.xml"/>
<import resource="applicationContext-scheduler.xml"/>
2.
对应的applicationContext.xml必须在/WEB-INF/web.xml里配置
<!-- Spring上下文配置 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/applicationContext.xml</param-value>
</context-param>