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 *




posted @ 2016-07-22 13:48  jason.bai  阅读(2651)  评论(0编辑  收藏  举报