Spring Quartz 和 Spring Task使用比較


Spring Quartz 和 Spring Task執行時間對比: 
1. Quartz設置同步模式時:一個任務的兩次執行的時間間隔是:“執行時間”和“trigger的設定間隔”的最大值 
2. Task默認同步模式:一個任務的兩次執行的時間間隔是:“執行時間”+“trigger的設定間隔”,即一個任務完成執行後,纔開始trigger計時

Spring Quartz 特點: 
1. 默認多線程異步執行 
2. 一個任務在上一次調度未完成執行,下一次調度時間到時,會另起一個線程開始新的調度。在業務繁忙時,一個任務或許會有多個線程在執行,導致數據處理異常。 
3. 單任務同步:配置屬性,可以使一個任務的一次調度在未完成時,而不會開啓下一次調度 
4. 多個任務同時運行,任務之間沒有直接的影響,多任務執行的快慢取決於CPU的性能 
5. SchedulerFactoryBean不能使用註解來配置?還是我沒找到註解的方法?

Spring Task特點: 
1. 默認單線程同步執行 
2. 一個任務執行完上一次之後,纔會執行下一次調度 
3. 多任務之間按順序執行,一個任務執行完成之後纔會執行另一個任務 
4. 多任務並行執行需要設置線程池 
5. 全程可以通過註解配置

Spring Quartz配置: 
1. 配置Job,job的targetObject可以使用spring註解@Service(value = “findObjectService”)配置的bean 
2. 配置Trigger 
3. 配置Scheduler


<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
  <bean id="findObjectJob" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"> 
    <property name="targetObject" ref="findObjectService" /> 
    <property name="targetMethod" value="startJob" /> 
    <property name="concurrent" value="false" />
  </bean> 
  <bean id="findObjectTrigger" 
        class="org.springframework.scheduling.quartz.SimpleTriggerBean">
    <property name="jobDetail" ref="findObjectJob" />
    <property name="repeatInterval" value="1000" />  
    <property name="startDelay" value="5000" />   
  </bean>
  <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
    <property name="triggers">
      <list>
        <ref bean="findObjectTrigger" />
      </list>
    </property>
  </bean>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

Spring Task配置: 
1. 執行方法添加@Scheduled註解 
2. 配置線程池

@Scheduled(cron = "0/1 * *  * * ? ")
public void startJob() {......}

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:task="http://www.springframework.org/schema/task"  
       xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
        http://www.springframework.org/schema/context  
        http://www.springframework.org/schema/context/spring-context-3.1.xsd
        http://www.springframework.org/schema/task  
        http://www.springframework.org/schema/task/spring-task-3.1.xsd">
<task:executor id="executor" pool-size="5" />
<task:scheduler id="scheduler" pool-size="5" />
<task:annotation-driven executor="executor" scheduler="scheduler" />
<context:annotation-config />  
<context:component-scan base-package="com.test1,com.test2"/>                             
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章