Spring+Quartz實現定時執行任務的配置


1.要想使用Quartz 必須要引入相關的包:以下是我在項目中gradle中的配置:

compile 'org.quartz-scheduler:quartz:2.1.1'

2.Scheduler的配置

  <bean id="mockJobSchedule"
        class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
    <property name="schedulerName">
      <value>mockJobSchedule</value>
    </property>
    <property name="triggers">
      <list>
        <ref bean="mockUpdateProposalJobTrigger" />
      </list>
    </property>
  </bean>

3.Trigger的配置

 <bean id="mockUpdateProposalJobTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
    <property name="jobDetail" ref="mockUpdateProposalJobDetail" />
    <property name="cronExpression" value="0 0/1 * * * ?" />
  </bean>

4.JobDetail的配置

<bean id="mockUpdateProposalJobDetail"
        class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
    <property name="concurrent" value="false"/>
 <!-- 是否允許任務並發執行。當值為false時,表示必須等到前一個線程處理完畢后才再啟一個新的線程 --> 
<property name="targetObject" ref="mockUpdateProposalJob" /> <property name="targetMethod" value="mockSynchronousProposal" /> </bean>

5.業務類的配置

<bean id="mockUpdateProposalJob" class="com.fndsoft.bcis.quartz.MockUpdateProposalJob"></bean> 
6.業務類源代碼
public class MockUpdateProposalJob {

  private Logger logger= LoggerFactory.getLogger(MockUpdateProposalJob.class);

  @Autowired
  private ProposalService proposalService;

  public void mockUpdateAccountJob() {
    logger.info("更新用戶賬戶表job啟動");
    proposalService.updateAccountJob();
    logger.info("更新用戶賬戶表job結束");
  }
}

7.關於cron表達式(來自網絡):

Cron 表達式包括以下 7 個字段:

  • 小時
  • 月內日期
  • 周內日期
  • 年(可選字段)

特殊字符

Cron 觸發器利用一系列特殊字符,如下所示:

  • 反斜線(/)字符表示增量值。例如,在秒字段中“5/15”代表從第 5 秒開始,每 15 秒一次。

  • 問號(?)字符和字母 L 字符只有在月內日期和周內日期字段中可用。問號表示這個字段不包含具體值。所以,如果指定月內日期,可以在周內日期字段中插入“?”,表示周內日期值無關緊要。字母 L 字符是 last 的縮寫。放在月內日期字段中,表示安排在當月最后一天執行。在周內日期字段中,如果“L”單獨存在,就等於“7”,否則代表當月內周內日期的最后一個實例。所以“0L”表示安排在當月的最后一個星期日執行。

  • 在月內日期字段中的字母(W)字符把執行安排在最靠近指定值的工作日。把“1W”放在月內日期字段中,表示把執行安排在當月的第一個工作日內。

  • 井號(#)字符為給定月份指定具體的工作日實例。把“MON#2”放在周內日期字段中,表示把任務安排在當月的第二個星期一。

  • 星號(*)字符是通配字符,表示該字段可以接受任何可能的值。

字段 允許值 允許的特殊字符 
秒 0-59 , - * / 
分 0-59 , - * / 
小時 0-23 , - * / 
日期 1-31 , - * ? / L W C 
月份 1-12 或者 JAN-DEC , - * / 
星期 1-7 或者 SUN-SAT , - * ? / L C # 
年(可選) 留空, 1970-2099 , - * /

表達式意義 
"0 0 12 * * ?" 每天中午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期間的每1分鍾觸發 
"0 0/5 14 * * ?" 在每天下午2點到下午2:55期間的每5分鍾觸發 
"0 0/5 14,18 * * ?" 在每天下午2點到2:55期間和下午6點到6:55期間的每5分鍾觸發 
"0 0-5 14 * * ?" 在每天下午2點到下午2:05期間的每1分鍾觸發 
"0 10,44 14 ? 3 WED" 每年三月的星期三的下午2:10和2:44觸發 
"0 15 10 ? * MON-FRI" 周一至周五的上午10:15觸發 
"0 15 10 15 * ?" 每月15日上午10:15觸發 
"0 15 10 L * ?" 每月最后一日的上午10:15觸發 
"0 15 10 ? * 6L" 每月的最后一個星期五上午10:15觸發 
"0 15 10 ? * 6L 2002-2005" 2002年至2005年的每月的最后一個星期五上午10:15觸發 
"0 15 10 ? * 6#3" 每月的第三個星期五上午10:15觸發 
每天早上6點

0 6 * * *

每兩個小時

0 */2 * * * 
晚上11點到早上8點之間每兩個小時,早上八點

0 23-7/2,8 * * *

每個月的4號和每個禮拜的禮拜一到禮拜三的早上11點

0 11 4 * 1-3 
1月1日早上4點

0 4 1 1 *





免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM