springboot实现定时器功能
2018-02-27 18:06
169 查看
springboot封装了quartz
1,scheduled.properties,定时配置文件配置
pay_order_risk_task.cron = 0 0/1 * * * ?
2,定时任务服务
@PropertySource("classpath:scheduled.properties")
@Component
@EnableScheduling // //打开quartz定时器总开关
public class taskService {
private static Logger logger = Logger.getLogger(taskService.class);
@Scheduled(cron = "${pay_order_risk_task.cron}") //每分钟执行一次statusCheck方法
public void statusCheck() {
logger.info("每分钟执行一次。开始……");
//statusTask.healthCheck();
logger.info("每分钟执行一次。结束。");
}
}
3,springboot启动类:这样当springboot项目启动后,定时任务就定时跑起来
@SpringBootApplication
public class Application {
private static Logger logger = Logger.getLogger(Application.class);
public static void main(String[] args) throws Exception {
SpringApplication.run(Application.class, args);
logger.info("My Spring Boot Application Started");
}
}
4,定时时间格式说明:
格式: 【秒】 【分】 【小时】 【日】 【月】 【周】 【年】
序号 说明 是否必填 允许填写的值 允许的通配符
1 秒 是 0-59 , - * /
2 分 是 0-59 , - * /
3 时 是 0-23 , - * /
4 日 是 1-31 , - * / ? L W
5 月 是 1-12 or JAN-DEC , - * /
6 周 是 1-7 or SUN-SAT , - * / ? L W
7 年 否 empty 或 1970-2099 , - * /
通配符说明:
* 表示所有值,例如:在分的字段上设置"*",表示每一分钟都会触发。
? 表示不知定值,使用场景为不需要关心当前设置这个字段的值。例如:要在每月的10号出发一个操作,但不关心是周几,
所以需要在周位置的那个字段设置为?,具体设置为0 0 0 10 * ? 年可以不设置。
- 表示区间。例如在小时上设置“10-12”,表示10点,11点,12点都会触发。
, 表示指定多个值,例如在周字段上设置“MON,WED,FRI”,表示周一,周三,周五触发。
/ 表示递增触发。例如在秒上设置“5/15”表示从5秒开始,每增15秒触发(5,20,35,50,...)。
在月字段上设置“1/3”表示每月1号开始,每隔3天出发一次。
L 表示最后的意思,在日字段上设置,表示当月的最后一天(依据当前月份,如果是2月还会依据是否是闰年[leap]),
在周字段上设置表示星期六,相当于"7"或"SAT"。如果在L前加数字,则表示该数字的最后一个,例如在周字段上设置“6L”这样的格式,
则表示本月的最后一个星期五。
#序号 表示在周字段上设置"6#3"表示每个月的第3个周六,注意如果指定"6#5",正好第五周没有周六,
则不会触发该配置(用在母亲节和父亲节再适合 不过了)。
W 表示离指定日期最近的那个工作日(周一至周五),例如在日字段上设置“15W”,表示离每月15号最近的那个工作日触发。
如果15号正好是周六,则找最近的周五(14号)触发,如果15号是周日,则找最近的下周一(16号)触发,如果15号是工作日(周一至周五),
则就在当天触发。如果指定格式为“1W”,它则表示每月1号往后最近的工作日触发。如果1号是周六,则在下周一(3号)触发
(注:W前只能跟数字).
'L' 和 'W'可以组合在一起使用。如果在日字段上设置"LW",则表示在本月的最后一个工作日触发(一般指发工资)。
小提示:周字段的设置,若使用英文字母是不区分大小写的。
常用示例:
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分每分触发
0 0/5 14 * * ? 每天下午的2点到2点59分(整点开始,每个分钟触发)
0 0/5 14,18 * * ? 每天下午的2点到2点59分和每天下午的18点到18点59分(整点开始,每个分钟触发)
0 0-5 14 * * ? 每天下午的2点到2点05分没分触发
0 10,44 14 ? 3 WED 表示3月份每周三下午的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分开始触发
0 11 11 11 11 ? 每年的11月11号11点11分触发
0 0 12 1/5 * ? 每月的第一个中午开始每隔5天触发一次
1,scheduled.properties,定时配置文件配置
pay_order_risk_task.cron = 0 0/1 * * * ?
2,定时任务服务
@PropertySource("classpath:scheduled.properties")
@Component
@EnableScheduling // //打开quartz定时器总开关
public class taskService {
private static Logger logger = Logger.getLogger(taskService.class);
@Scheduled(cron = "${pay_order_risk_task.cron}") //每分钟执行一次statusCheck方法
public void statusCheck() {
logger.info("每分钟执行一次。开始……");
//statusTask.healthCheck();
logger.info("每分钟执行一次。结束。");
}
}
3,springboot启动类:这样当springboot项目启动后,定时任务就定时跑起来
@SpringBootApplication
public class Application {
private static Logger logger = Logger.getLogger(Application.class);
public static void main(String[] args) throws Exception {
SpringApplication.run(Application.class, args);
logger.info("My Spring Boot Application Started");
}
}
4,定时时间格式说明:
格式: 【秒】 【分】 【小时】 【日】 【月】 【周】 【年】
序号 说明 是否必填 允许填写的值 允许的通配符
1 秒 是 0-59 , - * /
2 分 是 0-59 , - * /
3 时 是 0-23 , - * /
4 日 是 1-31 , - * / ? L W
5 月 是 1-12 or JAN-DEC , - * /
6 周 是 1-7 or SUN-SAT , - * / ? L W
7 年 否 empty 或 1970-2099 , - * /
通配符说明:
* 表示所有值,例如:在分的字段上设置"*",表示每一分钟都会触发。
? 表示不知定值,使用场景为不需要关心当前设置这个字段的值。例如:要在每月的10号出发一个操作,但不关心是周几,
所以需要在周位置的那个字段设置为?,具体设置为0 0 0 10 * ? 年可以不设置。
- 表示区间。例如在小时上设置“10-12”,表示10点,11点,12点都会触发。
, 表示指定多个值,例如在周字段上设置“MON,WED,FRI”,表示周一,周三,周五触发。
/ 表示递增触发。例如在秒上设置“5/15”表示从5秒开始,每增15秒触发(5,20,35,50,...)。
在月字段上设置“1/3”表示每月1号开始,每隔3天出发一次。
L 表示最后的意思,在日字段上设置,表示当月的最后一天(依据当前月份,如果是2月还会依据是否是闰年[leap]),
在周字段上设置表示星期六,相当于"7"或"SAT"。如果在L前加数字,则表示该数字的最后一个,例如在周字段上设置“6L”这样的格式,
则表示本月的最后一个星期五。
#序号 表示在周字段上设置"6#3"表示每个月的第3个周六,注意如果指定"6#5",正好第五周没有周六,
则不会触发该配置(用在母亲节和父亲节再适合 不过了)。
W 表示离指定日期最近的那个工作日(周一至周五),例如在日字段上设置“15W”,表示离每月15号最近的那个工作日触发。
如果15号正好是周六,则找最近的周五(14号)触发,如果15号是周日,则找最近的下周一(16号)触发,如果15号是工作日(周一至周五),
则就在当天触发。如果指定格式为“1W”,它则表示每月1号往后最近的工作日触发。如果1号是周六,则在下周一(3号)触发
(注:W前只能跟数字).
'L' 和 'W'可以组合在一起使用。如果在日字段上设置"LW",则表示在本月的最后一个工作日触发(一般指发工资)。
小提示:周字段的设置,若使用英文字母是不区分大小写的。
常用示例:
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分每分触发
0 0/5 14 * * ? 每天下午的2点到2点59分(整点开始,每个分钟触发)
0 0/5 14,18 * * ? 每天下午的2点到2点59分和每天下午的18点到18点59分(整点开始,每个分钟触发)
0 0-5 14 * * ? 每天下午的2点到2点05分没分触发
0 10,44 14 ? 3 WED 表示3月份每周三下午的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分开始触发
0 11 11 11 11 ? 每年的11月11号11点11分触发
0 0 12 1/5 * ? 每月的第一个中午开始每隔5天触发一次
相关文章推荐
- SpringBoot JPA实现增删改查、分页、排序、事务操作等功能
- spring boot实现验证码功能
- java Springboot实现多文件上传功能
- SpringBoot整合Mybatis实现增删改查的功能
- java spring实现定时器功能Timer
- SpringBoot+Shiro学习之“记住我”和“GIF验证码”功能的实现
- 基于spring boot的mysql使用pagehelper实现分页功能
- SpringBoot+thymeleaf简单实现登陆注册及记账功能
- springBoot+devtools实现热部署功能
- SpringBoot结合SpringSecurity实现图形验证码功能
- SpringBoot整合WebSocket实现实时消息群发功能
- springboot整合shiro登录失败次数限制功能的实现代码
- spring boot的定时器实现多线程
- Spring Boot整合Ehcache实现缓存功能
- Spring Boot实现邮件注册功能示例代码
- spring boot amqp实现延迟队列功能
- 通过Eureka、DiscoveryClient实现Spring Boot Admin管理功能
- SpringBoot集成Quartz实现定时器
- SpringMVC/SpringBoot使用easypoi实现Excel文件导入导出功能实现
- Spring Boot使用Netty SocketIO实现WebIM功能