java 定时器框架_最流行的java后台框架spring quartz定时任务

配置quartz 在spring中需要三个jar包:

quartz-1.8.5.jar、commons-collections-3.2.1.jar、commons-logging-1.1.jar

首先要配置我们的spring.xml

xmlns 多加下面的内容、

然后xsi:schemaLocation多加下面的内容、

最后是我们的task任务扫描注解

我的配置扫描位置是:

扫描的是com.test这样的包下的内容、

下面需要接口和实现(我的这几个java文件都是com.test的包下的、)

public interface IMyTestService {

public void myTest();

}

@Component //import org.springframework.stereotype.Component;

public class MyTestServiceImpl implements IMyTestService {

@Scheduled(cron="0/5 * * * * ? ") //每5秒执行一次

@Override

public void myTest(){

System.out.println("进入测试");

}

}

执行后控制台就会打印出   进入测试   了

需要注意的几点:

1、spring的@Scheduled注解  需要写在实现上、

2、 定时器的任务方法不能有返回值(如果有返回值,spring初始化的时候会告诉你有个错误、需要设定一个proxytargetclass的某个值为true、具体就去百度google吧)

3、实现类上要有组件的注解@Component

剩下的就是corn表达式了、具体使用以及参数请百度google、

【秒】   【分】  【时】   【日】  【月】   【周】  【年】

下面只例出几个式子

CRON表达式    含义

"0 0 12 * * ?"    每天中午十二点触发

"0 15 10 ? * *"    每天早上10:15触发

"0 15 10 * * ?"    每天早上10:15触发

"0 15 10 * * ? *"    每天早上10:15触发

"0 15 10 * * ? 2005"    2005年的每天早上10:15触发

"0 * 14 * * ?"    每天从下午2点开始到2点59分每分钟一次触发

"0 0/5 14 * * ?"    每天从下午2点开始到2:55分结束每5分钟一次触发

"0 0/5 14,18 * * ?"    每天的下午2点至2:55和6点至6点55分两个时间段内每5分钟一次触发

"0 0-5 14 * * ?"    每天14:00至14:05每分钟一次触发

"0 10,44 14 ? 3 WED"    三月的每周三的14:10和14:44触发

"0 15 10 ? * MON-FRI"    每个周一、周二、周三、周四、周五的10:15触发

有时候我们的任务(Job)需要再某些任务完成之后才能进行;例如从旧的数据库批量导数据的时候;需要现将被其他数据依赖的数据导入新的数据库;然后再进行关系的导入.。在这种情况下我们就可以使用Quartz的listener来做文章了。

首先我们写一个主任务的类,命名为MainJob;她的作用是作为一系列任务的开始点。

MainJob.java

package jobs;

import org.apache.log4j.Logger;

import org.quartz.JobExecutionContext;

import org.quartz.JobExecutionException;

import org.springframework.scheduling.quartz.QuartzJobBean;

public class MainJob extends QuartzJobBean {

private Logger logger=Logger.getLogger(getClass());

@Override

protected void executeInternal(JobExecutionContext arg0)

throws JobExecutionException {

// TODO Auto-generated method stub

logger.debug("Just say hi.");

}

}

然后我们新建另外一个任务(SecondJob)作为后续任务:

SecondJob.java

package jobs;

import org.apache.log4j.Logger;

import org.quartz.JobExecutionContext;

import org.quartz.JobExecutionException;

import org.springframework.scheduling.quartz.QuartzJobBean;

public class SecondJob extends QuartzJobBean {

private Logger logger=Logger.getLogger(getClass());

@Override

protected void executeInternal(JobExecutionContext arg0)

throws JobExecutionException {

// TODO Auto-generated method stub

logger.debug("I'm the second job.");

}

}

创建一个TriggerListener,重写其triggerComplete方法,并且添加一些方便spring注入的属性和方法。

NextJobTriggerListener.java

package listeners;

import org.apache.log4j.Logger;

import org.quartz.JobDetail;

import org.quartz.JobExecutionContext;

import org.quartz.Scheduler;

import org.quartz.Trigger;

import org.quartz.listeners.TriggerListenerSupport;

import org.springframework.scheduling.quartz.QuartzJobBean;

import org.springframework.scheduling.quartz.SimpleTriggerBean;

public class NextJobTriggerListener extends TriggerListenerSupport {

private Logger logger=Logger.getLogger(getClass());

private String name;

public String getName() {

return this.name;

}

public void setName(String name)

{

this.name=name;

}

private SimpleTriggerBean nextTrigger;

public void setNextTrigger(SimpleTriggerBean nextTrigger) {

this.nextTrigger=nextTrigger;

}

@Override

public void triggerComplete(Trigger trigger, JobExecutionContext context, int code) {

try{

Scheduler schduler=context.getScheduler();

JobDetail nextJob=nextTrigger.getJobDetail();

//查找名称和即将加入的任务一样的任务

JobDetail oldJob=schduler.getJobDetail(nextJob.getName(),nextJob.getGroup());

//查找名称和即将加入的触发器一样的触发器

Trigger oldTrigger=schduler.getTrigger(nextTrigger.getName(),nextTrigger.getGroup());

if(oldJob==null&&oldTrigger==null)//同名的任务和触发器都不存在

{

logger.debug("inside scheduleJob."+code);

schduler.scheduleJob(nextJob,nextTrigger);

}else//同名的任务或触发器

{

logger.debug("oldJob==null:"+(oldJob==null));

logger.debug("oldTrigger==null:"+(oldTrigger==null));

}

super.triggerComplete(trigger, context, code);

}catch(Exception e)

{

e.printStackTrace();

}

}

}

配置spring 的applicationContext.xml

applicationContext.xml

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xmlns:jee="http://www.springframework.org/schema/jee"

xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-2.0.xsd

http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-2.0.xsd">

class="org.springframework.scheduling.quartz.JobDetailBean">

jobs.MainJob

class="listeners.NextJobTriggerListener">

class="org.springframework.scheduling.quartz.SimpleTriggerBean">

6000

3600000

mainTriggerListener

class="org.springframework.scheduling.quartz.JobDetailBean">

jobs.SecondJob

class="org.springframework.scheduling.quartz.SimpleTriggerBean">

6000

6000

class="org.springframework.scheduling.quartz.SchedulerFactoryBean">

org.quartz.simpl.SimpleThreadPool

key="org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread">

true

开启服务器,输出

DEBUG [ MainJob.executeInternal(14) ] Just say hi.

DEBUG [ NextJobTriggerListener.triggerComplete(38) ] inside scheduleJob .3

DEBUG [SecondJob.executeInternal(14)] I'm the second job.

DEBUG [ NextJobTriggerListener.triggerComplete(43) ] oldJob==null:false

DEBUG [ NextJobTriggerListener.triggerComplete(44) ] oldTrigger== null:false

另外这里一个任务只绑定了一个简单的触发器,这样做是为了比较方便地可以检测到任务完成的情况;至于任务的具体内容就任由大家发挥了。写这篇文章希望能有人在其中获得启发。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值