由spring定时任务@Scheduled(cron = “0 0 0/1 * * ?“)引起的坑

这两天做到的一个功能,定时任务每整点生成一条记录,然后使用的cron表达式是:

@Scheduled(cron = "0 0 0/1 * * ?")意为每整点执行一次。

定时任务执行之后使用new Date() 拿到当前本机时间,作为记录的创建时间,使用时间格式化(yyyy-MM-dd HH:mm:00) 将秒钟设置成0。

 存入数据库之后发现创建时间正常是整点,但是记录时间(格式化之后的时间)少了一分钟。

原因分析

最终发现 @Scheduled(cron = "0 0 0/1 * * ?")可能会存在毫秒级别的误差,例如此时是2023-06-27 06:59:59.688  ,这时候虽然还没到七点,但是scheduled会检测到最近的时间(精确到秒) 是七点钟,就会开始执行定时任务,而此时new Date() 得到的实际是

2023-06-27 06:59:59.688 (作为创建时间)

格式化之后就是

2023-06-27 06:59:00.000(作为记录时间)

存入数据库之后 

2023-06-27 06:59:59.688 也会mysql四舍五入变成 2023-06-27 07:00:00.000

所以就出现了明明是用同一个时间进行处理操作,为什么记录时间会慢一分钟的现象。

处理方案

可以把定时任务的启动秒钟增加一点,这样无论怎么样都会在那一分钟触发

@Scheduled(cron = "2 0 0/1 * * ?")

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值