分布式定时任务锁ShedLock

勤奋不是嘴上说说而已,而是实际的行动,在勤奋的苦度中持之以恒,永不退却。业精于勤,荒于嬉;行成于思,毁于随。在人生的仕途上,我们毫不迟疑地选择勤奋,她是几乎于世界上一切成就的催产婆。只要我们拥着勤奋去思考,拥着勤奋的手去耕耘,用抱勤奋的心去对待工作,浪迹红尘而坚韧不拔,那么,我们的生命就会绽放火花,让人生的时光更加的闪亮而精彩。

导读:本篇文章讲解 分布式定时任务锁ShedLock,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

概述

Spring为定时任务提供一个易于实现的API。在没有部署应用程序的多个实例之前,它很有效。默认情况下,Spring无法处理多个实例上的调度程序同步,而是在每个节点上同时执行作业。ShedLock库确保计划任务只能同时运行一次,可以代替Quartz。ShedLock支持Mongo,Redis,Hazelcast,ZooKeeper以及任何基于JDBC驱动程序的数据库。
GitHub

入门

shedlock-spring基本依赖项:

<dependency>
    <groupId>net.javacrumbs.shedlock</groupId>
    <artifactId>shedlock-spring</artifactId>
</dependency>

再针对不同的锁,分别添加不同的依赖。如JDBC(数据库)锁添加:

<dependency>
    <groupId>net.javacrumbs.shedlock</groupId>
    <artifactId>shedlock-provider-jdbc-template</artifactId>
</dependency>

注意JDBC和JdbcTemplate是两种不同的锁。

ShedLock仅适用于具有共享数据库的环境。它在数据库中创建一个表或文档,用于存储有关当前锁的信息。为ShedLock创建一个PostgreSQL数据库表,以保留有关调度程序锁的信息:

CREATE TABLE shedlock(
  name VARCHAR(64),
  lock_until TIMESTAMP(3) NULL,
  locked_at TIMESTAMP(3) NULL,
  locked_by  VARCHAR(255),
  PRIMARY KEY (name)
)

Spring启动类加上@EnableScheduling@EnableSchedulerLock注解:

@SpringBootApplication
@EnableScheduling
@EnableSchedulerLock(defaultLockAtMostFor = "PT30S")
public class SpringApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringApplication.class, args);
    }
}

defaultLockAtMostFor参数指定在执行节点结束时应保留锁的默认时间量,使用ISO8601 Duration格式。

@Component
public class ShedLockConfig {
    @Bean
    public LockProvider lockProvider(DataSource dataSource) {
        return new JdbcTemplateLockProvider(dataSource);
    }

    @Bean
    public ScheduledLockConfiguration scheduledLockConfiguration(LockProvider lockProvider) {
        return ScheduledLockConfigurationBuilder.withLockProvider(lockProvider)
                .withPoolSize(10)
                .withDefaultLockAtMostFor(Duration.ofMinutes(10))
                .build();
    }
}

创建任务
方法添加注解@Scheduled@SchedulerLock注释:

@Component
class TaskScheduler {
	// 每15分钟
    @Scheduled(cron = "0 /15 * * * ?")
    @SchedulerLock(name = "scheduledTask", lockAtLeastForString = "PT1M", lockAtMostForString = "PT5M")
    public void scheduledTask() {
    }
}

@Scheduled 支持cron表达式;
@SchedulerLock注解有五个参数:

  • name:定时任务的名字,即数据库中的内个主键,必须唯一
  • lockAtMostFor:锁的最大时间单位为毫秒
  • lockAtMostForString:最大时间的字符串形式,例如:PT30S 代表30秒
  • lockAtLeastFor:锁的最小时间单位为毫秒
  • lockAtLeastForString:最小时间的字符串形式

在正常情况下,ShedLock会在任务完成后直接释放锁。@EnableSchedulerLock中提供默认值。

Redis

不建议使用

Redis

@Configuration
@EnableSchedulerLock(defaultLockAtMostFor = "PT1M")
public class ShedLockConfig {
    @Bean
    public LockProvider lockProvider(RedisTemplate redisTemplate) {
        return new RedisLockProvider(redisTemplate.getConnectionFactory());
    }
}
@Scheduled(cron = "0 0 */1 * * ?")
@SchedulerLock(name = "job1")
public void job1() {
    log.info("Start running job");
}
<dependency>
    <groupId>net.javacrumbs.shedlock</groupId>
    <artifactId>shedlock-provider-redis-spring</artifactId>
</dependency>

Jedis

<dependency>
    <groupId>net.javacrumbs.shedlock</groupId>
    <artifactId>shedlock-provider-redis-jedis</artifactId>
</dependency>

参考

shedlock-use

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/142312.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!