一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - 最流行的java后臺框架spring quartz定時任務

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

2020-03-06 19:46hebedich JAVA教程

近日項目開發中需要執行一些定時任務,比如需要在每天凌晨時候,分析一次前一天的日志信息,借此機會整理了一下定時任務的幾種實現方式,由于項目采用spring框架,所以我都將結合spring框架來介紹

配置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://www.springframework.org/schema/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的包下的、)

?
1
2
3
public interface IMyTestService {
    public void myTest();
}
?
1
2
3
4
5
6
7
8
@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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
<?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.xsd
http://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>
<!-- 任務調度工廠類 -->
<bean
class="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>
<prop
key="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>

開啟服務器,輸出

?
1
2
3
4
5
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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产成人综合亚洲亚洲欧美 | 精品国产国产综合精品 | 99精品视频在线观看免费 | 欧美69巨大jizzsex | 午夜dj影院在线视频观看完整 | 亚州一区二区 | 99午夜高清在线视频在观看 | 亚洲欧洲日产国码无码av | 精品久久久久久综合网 | 大陆黄色片| 国产精品秒播无毒不卡 | 国产精品视频在线观看 | 久久机热免费视频 | 无人在线视频高清免费播放 | 精品无码一区在线观看 | 久久久久久久伊人电影 | 亚洲免费闲人蜜桃 | 男人猛进女人屁股免费 | 久久九九亚洲精品 | 2019国产精品 | 亚洲国产精品无码中文在线 | 久久综合中文字幕佐佐木希 | 欧美亚洲天堂网 | 成人免费视频大全 | 湖南美女被黑人4p到惨叫 | 500福利第一巨人导航 | 男女污网站 | 精品日产1区2卡三卡麻豆 | 啊皇上你好大要知画 | 四虎1515hh.com | 精精国产xxxx视频在线播放器 | 香蕉eeww99国产精选播放 | 亚洲欧美日韩中文字幕久久 | 青柠在线完整高清观看免费 | 亚洲精品久久久久69影院 | 小早川怜子息梦精在线播放 | 特黄特色大片免费高清视频 | 青青操在线播放 | 婷婷天天| 糖心vlog麻豆精东影业传媒 | 无限资源在线观看播放 |