Springboot整合Redission及分布式锁


需要安装redis
引入依赖

<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson-spring-boot-starter</artifactId>
    <version>3.16.4</version>
</dependency>

配置RedissonClient客户端

@Configuration
public class RedissonConfig {

    @Value("${redisHost}")
    private String redisHost;
    @Value("${redisPassword}")
    private String redisPassword;

    @Bean
    public RedissonClient redissonClient() {
        Config config = new Config();
        //单机模式  依次设置redis地址和密码
        config.useSingleServer().setAddress(redisHost).setPassword(redisPassword);
        return Redisson.create(config);
    }
}

具有看门狗机制,自动续期,默认续30s 每隔10秒检查异常,最有一次续期检查,自动续到30s

    public String redissonLock(){

        ExecutorService fixedThreadPool = Executors.newFixedThreadPool(2);

        long start = System.currentTimeMillis();
        for (int i = 0; i < 2; i++) {
            fixedThreadPool.execute(() -> {
                RLock lock = redissonClient.getLock("lockKey");

                lock.lock();
                System.out.println("获取锁");
                try {
                    Thread.sleep(200000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }finally {
                    System.out.println(System.currentTimeMillis() - start);
                    if (lock.isLocked() && lock.isHeldByCurrentThread()) {
                        lock.unlock();
                    }
                }
            });
        }

        return "完成";
    }

尝试拿锁5s后停止重试,返回false 具有看门狗机制,自动延期 默认续30s 100秒后自动释放锁

  public String redissonTryLock() {

        ExecutorService fixedThreadPool = Executors.newFixedThreadPool(2);

        long start = System.currentTimeMillis();
        for (int i = 0; i < 2; i++) {
            fixedThreadPool.execute(() -> {
                RLock lock = redissonClient.getLock("lockKey");
                try {
                    if (lock.tryLock(5, 10, TimeUnit.SECONDS)) {
                        System.out.println(Thread.currentThread() + "获取锁");
                        Thread.sleep(20000);
                        System.out.println(Thread.currentThread() + "执行完成");
                    } else {
                        System.out.println(Thread.currentThread() + "没有获取锁");
                    }
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } finally {
                    if (lock.isLocked() && lock.isHeldByCurrentThread()) {
                        lock.unlock();
                        System.out.println(Thread.currentThread() + "主动释放锁" + (System.currentTimeMillis() - start));
                    } else {
                        System.out.println(Thread.currentThread() + "已无锁状态" + (System.currentTimeMillis() - start));
                    }
                }
            });
        }

        return "完成";
    }


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM