Springboot使用@Scheduled多节点启动时调度重复执行

在项目中使用@Scheduled注解实现定时调度十分方便,但是存在一个情况:当项目多节点部署时,调度会在每个节点上都执行。这就是个大问题了。网上解决方案也比较多,我用过两种方案:第一种是:指定一台主机,让调度只在一台主机上执行。第二种是:使用redis的分布式锁实现。

第一种,失去了分布式部署的宗旨。下面我简单的介绍下第二种

1、创建Redis工具类中,增加setNX方法,即"SET if Not Exists",成功返回true,失败返回flase:

   public Boolean setNX(String key, String value,long timeout, TimeUnit unit) {
        Boolean isExit = this.redisTemplate.getConnectionFactory().getConnection().setNX(key.getBytes(), value.getBytes());
        //如果设置成功,要设置其过期时间
        if (isExit) {
            redisTemplate.expire(key, timeout, unit);
        }
        return isExit;
    }

2、在业务代码中引用方法:

public void testtest() throws InterruptedException {
    try{
       if (!redisUtil.setNX("quartzFlag","1",30,TimeUnit.SECONDS)){//设置超时时间
            LOGGER.info("任务已执行");
            return;
        }
        
        业务代码....
        ...........
     } catch (Exception e) {
            e.printStackTrace();
        } finally {
            //任务完成后,释放redis锁
            RedisUtil.del("activityScheduledFlag");
      }

为防止程序意外终止,导致死锁,文章中用到了,任务完成释放锁和设置过期时间双重保障。

 

这是在使用的时候总结的。如有错误,请批评指正。

一切的真理都是实践中产生的。交给时间去验证吧

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
在Spring Boot项目中,可以使用@Scheduled注解来创建定时任务。该注解位于spring-context.jar包中。要使@Scheduled注解生效,需要在系统的启动类或配置类上添加@EnableScheduling注解。通过在方法上添加@Scheduled注解,可以指定方法在特定的时间间隔或固定的时间点执行。这样可以方便地实现定时任务的调度功能。同时,如果项目涉及到服务器集群的情况,建议使用任务调度平台来执行定时任务,以保证在多台服务器中选择一台进行任务的执行SpringBoot使用@Scheduled注解创建定时任务的方式可以参考文献中的示例代码,详细介绍了如何实现定时任务的功能,对于学习和工作具有一定的参考价值。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [SpringBoot中的定时任务@Scheduled的使用](https://blog.csdn.net/weixin_42218169/article/details/131113762)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [SpringBoot使用@Scheduled注解创建定时任务的实现](https://download.csdn.net/download/weixin_38524139/12724226)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值