部署过程的坑:quartz定时器时执行旧版本代码问题

   场景:近半月,反复定时器不按规定执行代码 ,其中有:

          1、代码中混杂旧版本代码,实际在最新版本中已经删除;

          2、执行时间混乱,历史中任何一次设置时间,在最新日期仍旧还在执行;

  分析:

      初步分析,要么是定时器出问题,要么代码有问题;

      结合部署时,是将整个包upload服务器,并将上一版本更名作为备份,以便万一需要时回滚,都放在webapps下,且未清理过work下的缓存。


   解决思路:

   1、反复确认,代码经单元测试是没问题的;

   2、定时器:单独设置定时器也没问题,能正确执行;

   3、缓存:清除work下的缓存后,还是报同样错误,看来不是缓存问题;

   4、部署:因为生产包与备份包在同一文件夹下,是不是运行时执行了历史版本呢?遂将所有备份包删除,只保留生产版本,重启tomcat后,连续4天正常,说明问题根源就在部署方式上,webapps下不能有非生产版本,否则会影响。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Quartz 是一个开源的、基于 Java 实现的定时任务调度框架,可以非常方便地实现定时任务的调度和管理。 下面是一个使用 Quartz 实现定时任务的示例代码: 1. 导入相关依赖包 ```xml <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.3.2</version> </dependency> ``` 2. 创建 Job 类 ```java public class MyJob implements Job { @Override public void execute(JobExecutionContext context) throws JobExecutionException { // 定时任务执行的逻辑代码 System.out.println("Hello Quartz!"); } } ``` 3. 创建 Trigger ```java // 创建一个每分钟执行一次的 Trigger Trigger trigger = TriggerBuilder.newTrigger() .withIdentity("trigger1", "group1") .withSchedule(SimpleScheduleBuilder.simpleSchedule() .withIntervalInSeconds(60) .repeatForever()) .build(); ``` 4. 创建 Scheduler ```java // 创建 Scheduler Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler(); scheduler.start(); // 创建 JobDetail JobDetail jobDetail = JobBuilder.newJob(MyJob.class) .withIdentity("job1", "group1") .build(); // 将 Trigger 和 JobDetail 注册到 Scheduler 中 scheduler.scheduleJob(jobDetail, trigger); ``` 完整的示例代码如下: ```java import org.quartz.*; import org.quartz.impl.StdSchedulerFactory; public class QuartzDemo { public static void main(String[] args) throws SchedulerException { // 创建 Scheduler Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler(); scheduler.start(); // 创建 JobDetail JobDetail jobDetail = JobBuilder.newJob(MyJob.class) .withIdentity("job1", "group1") .build(); // 创建一个每分钟执行一次的 Trigger Trigger trigger = TriggerBuilder.newTrigger() .withIdentity("trigger1", "group1") .withSchedule(SimpleScheduleBuilder.simpleSchedule() .withIntervalInSeconds(60) .repeatForever()) .build(); // 将 Trigger 和 JobDetail 注册到 Scheduler 中 scheduler.scheduleJob(jobDetail, trigger); } public static class MyJob implements Job { @Override public void execute(JobExecutionContext context) throws JobExecutionException { // 定时任务执行的逻辑代码 System.out.println("Hello Quartz!"); } } } ``` 这个示例代码中创建了一个每分钟执行一次的定时任务,你可以根据需要修改 Trigger 的执行规则来实现不同的定时任务
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值