SpringBoot 定时任务踩坑记录
来源:互联网 发布:淘宝买车分期付款 编辑:程序博客网 时间:2024/06/07 02:29
springboot已经支持了定时任务Schedule模块,一般情况已经完全能够满足我们的实际需求。今天就记录一下我使用 schedule 时候踩的坑吧。
想要使用定时,我们首先要开启支持,其实就是在启动类上面加个注解就 Ok。
1
2
3
4
5
6
7
@SpringBootApplication
@EnableScheduling
public
class
Application {
public
static
void
main(String[] args) {
SpringApplication.run(Application.
class
, args);
}
}
这篇博客的主题是记录踩的坑,具体定时任务怎么使用我就不写了
今天踩的这个坑和 cron 表达式有关,我们就先来看看 cron 表达式的解释吧:
Cron表达式是一个字符串,字符串以5或6个空格隔开,分为6或7个域,每一个域代表一个含义
解释
1
2
3
4
5
6
7
8
* 第一位,表示秒,取值
0
-
59
* 第二位,表示分,取值
0
-
59
* 第三位,表示小时,取值
0
-
23
* 第四位,日期天/日,取值
1
-
31
* 第五位,日期月份,取值
1
-
12
* 第六位,星期,取值
1
-
7
,星期一,星期二...,注:不是第
1
周,第二周的意思
另外:
1
表示星期天,
2
表示星期一。
* 第
7
为,年份,可以留空,取值
1970
-
2099
1
2
3
4
5
(*)星号:可以理解为每的意思,每秒,每分,每天,每月,每年...
(?)问号:问号只能出现在日期和星期这两个位置,表示这个位置的值不确定,每天
3
点执行,所以第六位星期的位置,我们是不需要关注的,就是不确定的值。同时:日期和星期是两个相互排斥的元素,通过问号来表明不指定值。比如,
1
月
10
日,比如是星期
1
,如果在星期的位置是另指定星期二,就前后冲突矛盾了。
(-)减号:表达一个范围,如在小时字段中使用“
10
-
12
”,则表示从
10
到
12
点,即
10
,
11
,
12
(,)逗号:表达一个列表值,如在星期字段中使用“
1
,
2
,
4
”,则表示星期一,星期二,星期四
(/)斜杠:如:x/y,x是开始值,y是步长,比如在第一位(秒)
0
/
15
就是,从
0
秒开始,每
15
秒,最后就是
0
,
15
,
30
,
45
,
60
另:*/y,等同于
0
/y
注: 这个是官方解释
1
2
3
4
5
6
0
0
3
* * ? 每天
3
点执行
0
5
3
* * ? 每天
3
点
5
分执行
0
5
3
? * * 每天
3
点
5
分执行,与上面作用相同
0
5
/
10
3
* * ? 每天
3
点的
5
分,
15
分,
25
分,
35
分,
45
分,
55
分这几个时间点执行
0
10
3
? *
1
每周星期天,
3
点
10
分 执行,注:
1
表示星期天
0
10
3
? *
1
#
3
每个月的第三个星期,星期天 执行,#号只能出现在星期的位置
在此我要说明,springBoot 中的 schedule 支持的 cron 表达式和这个不太相符,官方说的星期表示,1是周天,依次类推,但是我在测试过程中,1实际上代表的就是周一,口说无凭
那我就来贴代码和测试结果吧.
1
2
3
4
5
6
7
8
@Component
@EnableScheduling
public
class
Task {
private
static
final
Logger LOGGER = MyLogger.getLogger(Task.
class
);
@Scheduled
(cron =
"0 46 20 ? * 1"
)
public
void
task() {
LOGGER.info(
"听说今天是周日"
);
}
测试结果:
1
2017
-
05
-
08
20
:
46
:
00.006
INFO
18838
--- [pool-
1
-thread-
1
] com.yiyexy.task.Task : 听说今天是周日
按照上面的解释来讲,第六域是星期,并且值是1那么代表是周日运行,但是我的运行结果表明是周一运行,我在此表示很无奈。
最后我觉得用单词来表示周几,这样就不会出这种问题了,于是
1
2
3
4
5
6
7
8
9
@Component
@EnableScheduling
public
class
Task {
private
static
final
Logger LOGGER = MyLogger.getLogger(Task.
class
);
@Scheduled
(cron =
"0 49 20 ? * MON"
)
public
void
task() {
LOGGER.info(
"听说今天是周日"
);
}
}
测试结果:
1
2017
-
05
-
08
20
:
49
:
00.005
INFO
18864
--- [pool-
1
-thread-
1
] com.yiyexy.task.Task : 听说今天是周日
好了,这个坑就记录到这吧,最后奉上一句,时间是检验真理的唯一标准。
阅读全文
0 0
- SpringBoot 定时任务踩坑记录
- SpringBoot定时任务说明
- springboot定时任务
- springboot(九):定时任务
- springboot(九):定时任务
- springboot 定时任务
- SpringBoot-@Schedule定时任务
- SpringBoot定时任务SchedulingTasks
- SpringBoot 定时任务
- SpringBoot 定时任务
- SpringBoot 定时任务
- springboot (7) 定时任务
- SpringBoot定时任务
- SpringBoot (九) :定时任务
- springboot(九):定时任务
- springboot 定时任务
- springboot实现定时任务
- SpringBoot 定时任务
- 处理多维度变化——桥接模式(一)
- unity的canvas scaler组件
- Python--sys模块
- unity 中将c#打包成dll中,需要注意的地方
- 深入Android 【四】 —— 组件调用
- SpringBoot 定时任务踩坑记录
- DllImportAttribute 类
- 系统总线(二)
- Eigen 求解线性方程组
- 使用kickstart创建逻辑卷管理LVM分区
- 阿里云maven仓库
- spring aop 注解以及各种织入点语法
- 《算法图解》第四章快速排序
- Python--command模块