Scheduled中cron表达式周几问题排查

用户需求每周第二个周五下午五点发一条消息,于是找了两个在线的cron网站测试了下
"0 0 17 ? * 6#2"

在线Cron表达式生成器

8月12号是周五看起来没什么问题,加了日志,部署后发现实际周六才执行。
于是找了找资料,大部分还是6表示周五,后来发现阿里云ECS文章在不同目录下不同文章对cron的定义有差异。
CRON 表达式详解 - 金融分布式架构 SOFAStack - 阿里云
首页>金融分布式架构 SOFAStack>中间件>任务调度>简单任务>CRON 表达式详解

Cron表达式 - 云服务器 ECS - 阿里云
首页>云服务器 ECS>运维与监控>云助手>Cron表达式

问题排查

资料不多只能自己去排查下,首先找到Scheduled中cron重要的解析类,CronExpression

 注释明确表明了,5表示周五,而且#前面支持英文写法。

之后怀疑是不是时区问题导致,我们默认时区是"Asia/Shanghai",于是跟着debug找到解析#的代码QuartzCronField#parseDaysOfWeek

 代码的入参只有#前面的数字,0=7代表周日,1代表周一,依次类推,直接根据枚举类的位置返回,没看出根据时区去运算。

结论:

1:cron表达式不是完全通用的,在Scheduled中1,2,3,4,5,6,7分别表示 “MON,TUE,WED,THU,FRI,SAT,SUN”;0也表示SUN; 在Quartz中1,2,3,4,5,6,7分别表示 “SUN,MON,TUE,WED,THU,FRI,SAT”;

2.可以尽量用Fri这种英文表示周几。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值