前期工作:(引入相关 JAR )
- <spring.quartz>1.8.4</spring.quartz>
- <!--spring 定时 -->
- <dependency>
- <groupId>org.quartz-scheduler</groupId>
- <artifactId>quartz</artifactId>
- <version>${spring.quartz}</version>
- </dependency>
1): 注解方式整合定时器
编写一个测试类:
- package com.gdbd.time;
- import org.apache.log4j.Logger;
- /**
- * @Description: Spring 定时器测试类
- * @Author: DGBD
- * @CreateDate: 2019/1/12 10:06
- * @UpdateUser: yc
- * @UpdateDate: 2019/1/12 10:06
- * @UpdateRemark: 修改内容
- * @博客地址: https://www.cnblogs.com/mlq2017/
- * @Version: 1.0
- */
- public class TimeTest {
- private final Logger LOGGER = Logger.getLogger(TimeTest.class);
- public void tesTime() {
- LOGGER.info("定时器执行成功!--------------------------------------");
- for (int i = 0; i <10; i++) {
- System.out.println("i 的个数为 =" + i);
- }
- }
- }
配置文件: spring-timeAnnotation.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:task="http://www.springframework.org/schema/task"
- xmlns:context="http://www.springframework.org/schema/context"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/task
- http://www.springframework.org/schema/task/spring-task.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context.xsd">
- <!--
- ===================================================
- ======================= 注解版 ======================
- ===================================================
- -->
- <!-- task 任务注解扫描包(定时器开关) -->
- <!-- 用定时器注解 -->
- <task:annotation-driven/>
- <!-- 扫描位置是 -->
- <context:component-scan base-package="com.gdbd.time"/>
- </beans>
2): 配置文件整合定时器
编写测试类:
- package com.gdbd.time;
- import org.springframework.scheduling.annotation.Scheduled;
- import org.springframework.stereotype.Component;
- import java.util.Date;
- /**
- * @Description: 注解版定时器
- * @Author: DGBD
- * @CreateDate: 2019/1/12 10:20
- * @UpdateUser: yc
- * @UpdateDate: 2019/1/12 10:20
- * @UpdateRemark: 修改内容
- * @博客地址: https://www.cnblogs.com/mlq2017/
- * @Version: 1.0
- */
- @Component
- public class AnnotationQuartz {
- @Scheduled(cron = "0 0/1 15,* * * ?")
- public void test() {
- String dateStr = new Date().toString();
- System.out.println("每分钟执行一次:" + dateStr);
- }
- }
配置文件: spring-time.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"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans.xsd">
- <!--
- ===================================================
- ======================= 配置版 ======================
- ===================================================
- -->
- <!-- 要调用的工作类 -->
- <bean id="timeTestBean" class="com.gdbd.time.TimeTest"></bean>
- <!-- 定义调用对象和调用对象的方法 -->
- <bean id="timeJobe" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
- <!-- 调用的类 -->
- <property name="targetObject" ref="timeTestBean"></property>
- <!-- 调用类中的方法 -->
- <property name="targetMethod" value="tesTime"></property>
- </bean>
- <!-- 定义触发时间 -->
- <bean id="doTime" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
- <property name="jobDetail" ref="timeJobe"></property>
- <!-- cron 表达式 -->
- <property name="cronExpression">
- <value>0/2 * * * * ?</value><!-- 每 2 秒执行一次 -->
- </property>
- </bean>
- <!-- 总管理类 如果将 lazy-init='false'那么容器启动就会执行调度程序 -->
- <bean id="startQuertz" lazy-init="false" autowire="no"
- class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
- <property name="triggers">
- <list>
- <ref bean="doTime"/>
- </list>
- </property>
- </bean>
- </beans>
时间在线生成工具:( http://cron.qqe2.com/ )
常用设置文档:
按顺序依次为
1 秒(0~59)
2 分钟(0~59)
3 小时(0~23)
4 天(0~31)
5 月(0~11)
6 星期(1~7 1=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT)
7. 年份(1970-2099)
其中每个元素可以是一个值(如 6), 一个连续区间(9-12), 一个间隔时间(8-18/4)(/ 表示每隔 4 小时), 一个列表(1,3,5), 通配符.
由于 "月份中的日期" 和 "星期中的日期" 这两个元素互斥的, 必须要对其中一个设置?.
0 0 10,14,16 * * ? 每天上午 10 点, 下午 2 点, 4 点
0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时
0 0 12 ? * WED 表示每个星期三中午 12 点
"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 触发
有些子表达式能包含一些范围或列表
例如: 子表达式 (天(星期)) 可以为 "MON-FRI","MON,WED,FRI","MON-WED,SAT"
"*" 字符代表所有可能的值
"/" 字符用来指定数值的增量
例如: 在子表达式 (分钟) 里的 "0/15" 表示从第 0 分钟开始, 每 15 分钟
在子表达式 (分钟) 里的 "3/20" 表示从第 3 分钟开始, 每 20 分钟 (它和 "3,23,43") 的含义一样
"?" 字符仅被用于天 (月) 和天 (星期) 两个子表达式, 表示不指定值
当 2 个子表达式其中之一被指定了值以后, 为了避免冲突, 需要将另一个子表达式的值设为 "?"
"L" 字符仅被用于天 (月) 和天 (星期) 两个子表达式, 它是单词 "last" 的缩写
如果在 "L" 前有具体的内容, 它就具有其他的含义了. 例如:"6L" 表示这个月的倒数第6天
注意: 在使用 "L" 参数时, 不要指定列表或范围, 因为这会导致问题
W 字符代表着平日(Mon-Fri), 并且仅能用于日域中. 它用来指定离指定日的最近的一个平日. 大部分的商业处理都是基于工作周的, 所以 W 字符可能是非常重要的.
例如, 日域中的 15W 意味着 "离该月 15 号的最近一个平日." 假如 15 号是星期六, 那么 trigger 会在 14 号 (星期五) 触发, 因为星期四比星期一离 15 号更近.
C: 代表 "Calendar" 的意思. 它的意思是计划所关联的日期, 如果日期没有被关联, 则相当于日历中所有日期. 例如 5C 在日期字段中就相当于日历 5 日以后的第一天.
1C 在星期字段中相当于星期日后的第一天.
字段 允许值 允许的特殊字符
秒 0-59 , - */
分 0-59 , - */
小时 0-23 , - */
日期 1-31 , - * ? / L W C
月份 1-12 或者 JAN-DEC , - */
星期 1-7 或者 SUN-SAT , - * ? / L C #
年(可选) 留空, 1970-2099 , - */
来源: https://www.cnblogs.com/mlq2017/p/10270221.html