国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

最流行的java后臺框架spring quartz定時任務

2019-11-26 14:48:18
字體:
來源:轉載
供稿:網友

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

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

首先要配置我們的spring.xml

xmlns 多加下面的內容、

xmlns:task="

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

http://www.springframework.org/schema/task 
http://www.springframework.org/schema/task/spring-task-3.1.xsd 

最后是我們的task任務掃描注解

<task:annotation-driven/> 

我的配置掃描位置是:

復制代碼 代碼如下:
<context:annotation-config/> 
    <bean class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor"/> 
    <context:component-scan base-package="com.test"/> 

掃描的是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());@Overrideprotected void executeInternal(JobExecutionContext arg0)throws JobExecutionException {// TODO Auto-generated method stublogger.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());@Overrideprotected void executeInternal(JobExecutionContext arg0)throws JobExecutionException {// TODO Auto-generated method stublogger.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;}@Overridepublic 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

<?xml version="1.0"encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"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.xsdhttp://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-2.0.xsd"><!-- 主任務 --><bean id="mainJob"class="org.springframework.scheduling.quartz.JobDetailBean"><!-- 運行的類 --><property name="jobClass"><value> jobs.MainJob </value></property></bean><!-- 主任務的監聽器 --><bean id="mainTriggerListener"class="listeners.NextJobTriggerListener"><!-- 下個觸發器 --><property name="nextTrigger" ref="secondTrigger"></property><!-- 監聽器名稱 --><property name="name" value="mainTriggerListener"></property></bean><!-- 主任務的觸發器 --><bean id="mainTrigger"class="org.springframework.scheduling.quartz.SimpleTriggerBean"><property name="jobDetail"><!-- 上面創建的任務調度對象 --><ref bean="mainJob" /></property><!-- 啟動60秒后執行任務調度的excute方法 --><property name="startDelay"><value> 6000 </value></property><!-- 運行次數 --><property name="repeatCount"><value> </value></property><!-- 隔一個小時運行一次(貌似多余,不寫會報錯) --><property name="repeatInterval"><value> 3600000 </value></property><property name="triggerListenerNames"><list><value> mainTriggerListener </value></list></property></bean><!-- 后續任務 --><bean id="secondJob"class="org.springframework.scheduling.quartz.JobDetailBean"><!-- 運行的類 --><property name="jobClass"><value> jobs.SecondJob </value></property></bean><!-- 后續任務的觸發器 --><bean id="secondTrigger"class="org.springframework.scheduling.quartz.SimpleTriggerBean"><property name="jobDetail"><!-- 上面創建的任務調度對象 --><ref bean="secondJob" /></property><!-- 啟動6秒后執行任務調度的excute方法 --><property name="startDelay"><value> 6000 </value></property><!-- 運行次數 --><property name="repeatCount"><value> </value></property><!-- 隔一個小時運行一次(貌似多余,不寫會報錯) --><property name="repeatInterval"><!--<value>3600000</value>--><value> 6000 </value></property></bean><!-- 任務調度工廠類 --><beanclass="org.springframework.scheduling.quartz.SchedulerFactoryBean"><!-- 這一部分的配置不用管 --><property name="quartzProperties"><props><prop key="org.quartz.threadPool.class">org.quartz.simpl.SimpleThreadPool</prop><prop key="org.quartz.threadPool.threadCount"> </prop><prop key="org.quartz.threadPool.threadPriority"></prop><propkey="org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread">true</prop></props></property><!-- 觸發器,可以放一大堆觸發器 --><property name="triggers"><list><!-- 在這里加 --><ref bean="mainTrigger"/></list></property><property name="triggerListeners"><list><!-- 觸發器的監聽器 --><ref bean="mainTriggerListener" /></list></property></bean></beans>

開啟服務器,輸出

DEBUG [ MainJob.executeInternal(14) ] Just say hi.DEBUG [ NextJobTriggerListener.triggerComplete(38) ] inside scheduleJob .3DEBUG [SecondJob.executeInternal(14)] I'm the second job.DEBUG [ NextJobTriggerListener.triggerComplete(43) ] oldJob==null:falseDEBUG [ NextJobTriggerListener.triggerComplete(44) ] oldTrigger== null:false

另外這里一個任務只綁定了一個簡單的觸發器,這樣做是為了比較方便地可以檢測到任務完成的情況;至于任務的具體內容就任由大家發揮了。寫這篇文章希望能有人在其中獲得啟發。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 东阳市| 崇左市| 高青县| 社会| 桂林市| 博客| 民权县| 蒙城县| 锡林郭勒盟| 江安县| 潞西市| 泰兴市| 容城县| 宁陵县| 西昌市| 张家口市| 正宁县| 太和县| 黄龙县| 锡林郭勒盟| 蛟河市| 常宁市| 宁陕县| 普宁市| 惠州市| 兴业县| 泊头市| 马山县| 长子县| 南丹县| 勃利县| 阜康市| 津市市| 黔西| 霍州市| 莱州市| 明溪县| 上蔡县| 石林| 龙陵县| 桂阳县|