Sping Boot 定时任务 修改系统时间 定时任务失效!!!

              Sping Boot 定时任务  说到底也就是说到某个时间点会执行某个功能的一个任务  所以说当你设置了要执行的时间 开启服务 当到了时间点后就会去执行这项功能

假设 如果我要设置每天凌晨两点执行删除一个月前的Log 日志表的数据  然后修改系统时间 为凌晨一点58 在开启服务   到两点的时候就会去执行了 这是可以的


但是现在问题就是又 把系统时间修改到明天凌晨时间一点59分    按道理来说到两点后也会执行   因为设置的是每天凌晨两点执行  结果没有 

问题就是 摘一段百度上的说法 就是

Timer类的调度是基于绝对的时间的,而不是相对的时间,因此Timer类对系统时钟的变化是敏感的,举个例子,加入你希望任务1每个10秒执行一次,某个时刻,你将系统时间提前了6秒,那么任务1就会在4秒后执行,而不是10秒后。而在 ScheduledThreadPoolExecutor,任务的调度是基于相对时间的,原因是它在任务的内部 存储了该任务距离下次调度还需要的时间(使用的是基于 System#nanoTime实现的相对时间 ,不会因为系统时间改变而改变,如距离下次执行还有10秒,不会因为将系统时间调前6秒而变成4秒后执行)。


总结就是 当你开启服务后 修改服务系统时间  定时任务没启动  因为它读取的时间是启动服务之前的时间  

解决: 在重启一遍服务




  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
概述: 本课程设计旨在通过结合Spring Boot和Hadoop技术,设计和实现一个功能强大的网盘系统。 网盘系统是一种云存储服务,用户可以通过网络上传、下载和管理自己的文件。它提供了方便的文件存储和共享功能,可以随时随地访问和管理文件。通过本课程设计,学生将学习如何利用Spring Boot框架构建一个灵活、高效的Web应用程序,并使用Hadoop分布式文件系统来实现大规模文件存储和管理。 课程设计主要包括以下几个方面: 1. 系统需求分析:对网盘系统的功能和特性进行详细分析和定义,包括用户注册与登录、文件上传与下载、文件管理与分享等。 2. 系统设计:根据需求分析结果,进行系统架构设计、数据库设计等,确定系统的组成部分和交互方式。 3. 环境搭建:安装和配置Spring Boot和Hadoop环境,准备开发所需的工具和资源。 4. 前端开发:使用HTML、CSS、JavaScript等前端技术开发用户界面,实现用户交互和界面展示功能。 5. 后端开发:使用Spring Boot框架开发后端接口,处理用户请求,实现文件管理和存储功能。 6. Hadoop集成:利用Hadoop分布式文件系统,实现文件的分布式存储和管理,提高系统的可扩展性和容错性。 7. 系统测试与优化:对系统进行测试,包括功能测试、性能测试等,并进行优化和改进,确保系统的稳定性和可靠性。 通过完成本课程设计,学生将掌握Spring Boot和Hadoop的开发技术,了解网盘系统的设计和实现原理,并具备开发和部署类似系统的能力。同时,学生还将培养团队协作、问题解决和项目管理等方面的能力,为将来的工作和学习打下坚实的基础。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值