当前位置: 首页 > article >正文

Spring Scheduling Tasks+Redis实现分布式定时任务

Spring Scheduling Tasks+Redis实现分布式定时任务

介绍

ShedLock是一个在分布式环境中使用的定时任务框架,用于解决在分布式环境中的多个实例的相同定时任务在同一时间点重复执行的问题。ShedLock确保计划的任务最多同时执行一次。如果一个任务正在一个节点上执行,它会获得一个锁,该锁将阻止从另一个节点(或线程)执行同一任务。请注意,如果一个任务已经在一个节点上执行,则在其他节点上的执行不会等待,只是将其跳过。简单来说,ShedLock本身只做一件事情:保证一个任务最多同时执行一次。所以如官网所说的,ShedLock不是一个分布式调度器,只是一个锁!

实现

引入依赖

<!-- Spring Scheduling Tasks -->
<dependency>
    <groupId>net.javacrumbs.shedlock</groupId>
    <artifactId>shedlock-spring</artifactId>
    <version>4.23.0</version>
</dependency>

<!-- Spring Scheduling Tasks Redis -->
<dependency>
    <groupId>net.javacrumbs.shedlock</groupId>
    <artifactId>shedlock-provider-redis-spring</artifactId>
    <version>4.23.0</version>
</dependency>

配置

@Configuration
public class ScheduledLockConfig {

    @Bean
    public LockProvider lockProvider(RedisConnectionFactory connectionFactory) {
        return new RedisLockProvider(connectionFactory);
    }
}

配置启动类

@EnableScheduling
@EnableSchedulerLock(defaultLockAtMostFor = "3m")
@SpringBootApplication()
public class SystemApplication {

    public static void main(String[] args) {
        SpringApplication.run(SystemApplication.class, args);
    }

}

@EnableScheduling:开启Spring自带定时任务

@EnableSchedulerLock:开启分布式定时任务服务,defaultLockAtMostFor默认最多锁定多久,这里设置的3分钟

创建定时任务

@Slf4j
@Component
public class LogJob {

    /**
     * 每月1号凌晨4点执行
     */
    @Scheduled(cron = "0 0 4 1 * ?")
    //name:锁的唯一标识符
    //lockAtMostFor:指定如果任务执行完成但未能正确释放锁时,锁最多保持的时间,防止死锁,这里设置的2分钟
    //lockAtLeastFor:锁至少持有多久,对于那些执行速度可能非常快的任务特别有用,它保证了即使任务快速完成,锁也会保持一定的时间,从而防止过于频繁地尝试获取锁的情况。这里设置1分钟
    @SchedulerLock(name = "xxx", lockAtMostFor = "2m", lockAtLeastFor = "1m")
    public void clearGatewayLog() {
        try {
            log.info("开始执行-分布式定时任务");
            ...业务逻辑
            log.info("执行完成-分布式定时任务");
        } catch (Exception e) {
            log.error("执行失败-分布式定时任务", e);
        }
    }
}

参考

https://blog.csdn.net/a767815662/article/details/104459814
https://sca.aliyun.com/docs/2023/user-guide/schedulerx/quick-start/?# Spring Scheduling Tasks+Redis实现分布式定时任务

介绍

ShedLock是一个在分布式环境中使用的定时任务框架,用于解决在分布式环境中的多个实例的相同定时任务在同一时间点重复执行的问题。ShedLock确保计划的任务最多同时执行一次。如果一个任务正在一个节点上执行,它会获得一个锁,该锁将阻止从另一个节点(或线程)执行同一任务。请注意,如果一个任务已经在一个节点上执行,则在其他节点上的执行不会等待,只是将其跳过。简单来说,ShedLock本身只做一件事情:保证一个任务最多同时执行一次。所以如官网所说的,ShedLock不是一个分布式调度器,只是一个锁!

实现

引入依赖

<!-- Spring Scheduling Tasks -->
<dependency>
    <groupId>net.javacrumbs.shedlock</groupId>
    <artifactId>shedlock-spring</artifactId>
    <version>4.23.0</version>
</dependency>

<!-- Spring Scheduling Tasks Redis -->
<dependency>
    <groupId>net.javacrumbs.shedlock</groupId>
    <artifactId>shedlock-provider-redis-spring</artifactId>
    <version>4.23.0</version>
</dependency>

配置

@Configuration
public class ScheduledLockConfig {

    @Bean
    public LockProvider lockProvider(RedisConnectionFactory connectionFactory) {
        return new RedisLockProvider(connectionFactory);
    }
}

配置启动类

@EnableScheduling
@EnableSchedulerLock(defaultLockAtMostFor = "3m")
@SpringBootApplication()
public class SystemApplication {

    public static void main(String[] args) {
        SpringApplication.run(SystemApplication.class, args);
    }

}

@EnableScheduling:开启Spring自带定时任务

@EnableSchedulerLock:开启分布式定时任务服务,defaultLockAtMostFor默认最多锁定多久,这里设置的3分钟

创建定时任务

@Slf4j
@Component
public class LogJob {

    /**
     * 每月1号凌晨4点执行
     */
    @Scheduled(cron = "0 0 4 1 * ?")
    //name:锁的唯一标识符
    //lockAtMostFor:指定如果任务执行完成但未能正确释放锁时,锁最多保持的时间,防止死锁,这里设置的2分钟
    //lockAtLeastFor:锁至少持有多久,对于那些执行速度可能非常快的任务特别有用,它保证了即使任务快速完成,锁也会保持一定的时间,从而防止过于频繁地尝试获取锁的情况。这里设置1分钟
    @SchedulerLock(name = "xxx", lockAtMostFor = "2m", lockAtLeastFor = "1m")
    public void clearGatewayLog() {
        try {
            log.info("开始执行-分布式定时任务");
            ...业务逻辑
            log.info("执行完成-分布式定时任务");
        } catch (Exception e) {
            log.error("执行失败-分布式定时任务", e);
        }
    }
}

参考

https://blog.csdn.net/a767815662/article/details/104459814
https://sca.aliyun.com/docs/2023/user-guide/schedulerx/quick-start/?


http://www.kler.cn/a/553443.html

相关文章:

  • CRMEB JAVA多商户外贸版演示地址
  • 【JavaScript】《JavaScript高级程序设计 (第4版) 》笔记-Chapter17-事件
  • fpga助教面试题
  • 【论文学习】RVS-FDSC:一种基于四方向条带卷积的视网膜血管分割方法以增强特征提取
  • 开源之夏经验分享|Koupleless 社区魏照华:开源精神是场永不停歇的接力
  • C++ Primer 构造函数再探
  • 【学习笔记】Cadence电子设计全流程(一)Cadence 生态及相关概念
  • 碳化硅(SiC)功率器件:新能源汽车的“心脏”革命与技术突围
  • Spotify AI 技术(1)使用 TensorFlow 和 TF-Agents
  • top命令输出内容详解
  • C++蓝桥杯基础篇(四)
  • 使用 Qt 插件和 SQLCipher 实现 SQLite 数据库加密与解密
  • Vue2和Vue3的Hooks有什么区别
  • nginx ngx_http_module(8) 指令详解
  • Starlink卫星动力学系统仿真建模番外篇6-地球敏感器
  • 【AI战略思考15】我对做自媒体视频博主的初步探索和一些思考
  • 【java基础】Java 中的 this 关键字
  • Django中数据库迁移命令
  • 网络原理-HTTP/HTTPS
  • 介绍一下 Octave