用户需求每周第二个周五下午五点发一条消息,于是找了两个在线的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这种英文表示周几。