多平台统一管理软件接口,如何实现多平台统一管理软件接口
237
2023-07-25
最流行的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 多加下面的内容、
xmlns:task="http://springframework.org/schema/task"
然后xsi:schemaLocation多加下面的内容、
http://springframework.org/schema/task
http://springframework.org/schema/task/spring-task-3.1.xsd
最后是我们的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、实现类上要http://有组件的注解@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://w3.org/2001/XMLSchema-instance" xmlns:jee="http://springframework.org/schema/jee" xsi:schemaLocation="http://springframework.org/schema/beanshttp://springframework.org/schema/beans/spring-beans-2.0.xsd http://springframework.org/schema/jee http://springframework.org/schema/jee/spring-jee-2.0.xsd"> class="org.springframework.scheduling.quartz.JobDetailBean"> class="listeners.NextJobTriggerListener"> class="org.springframework.scheduling.quartz.SimpleTriggerBean"> class="org.springframework.scheduling.quartz.JobDetailBean"> class="org.springframework.scheduling.quartz.SimpleTriggerBean"> class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> org.quartz.simpl.SimpleThreadPool key="org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread"> true
xmlns:xsi="http://w3.org/2001/XMLSchema-instance"
xmlns:jee="http://springframework.org/schema/jee"
xsi:schemaLocation="http://springframework.org/schema/beanshttp://springframework.org/schema/beans/spring-beans-2.0.xsd
http://springframework.org/schema/jee http://springframework.org/schema/jee/spring-jee-2.0.xsd">
class="org.springframework.scheduling.quartz.JobDetailBean">
class="org.springframework.scheduling.quartz.JobDetailBean">
class="listeners.NextJobTriggerListener">
class="listeners.NextJobTriggerListener">
class="org.springframework.scheduling.quartz.SimpleTriggerBean">
class="org.springframework.scheduling.quartz.SimpleTriggerBean">
class="org.springframework.scheduling.quartz.JobDetailBean">
class="org.springframework.scheduling.quartz.JobDetailBean">
class="org.springframework.scheduling.quartz.SimpleTriggerBean">
class="org.springframework.scheduling.quartz.SimpleTriggerBean">
class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> org.quartz.simpl.SimpleThreadPool key="org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread"> true
class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
org.quartz.simpl.SimpleThreadPool
key="org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread"> true
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
另外这里一个任务只绑定了一个简单的触发器,这样做是为了比较方便地可以检测到任务完成的情况;至于任务的具体内容就任由大家发挥了。写这篇文章希望能有人在其中获得启发。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~