Springboot中使用Redisson实现分布式锁

发布时间:2022-07-03 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了Springboot中使用Redisson实现分布式锁脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

1. 概述

老话说的好:便宜没好货,有价值的商品,即使再贵,也有人会买。

 

言归正传,今天继续讨论有关“锁”的话题,synchronized 和 ReentrantLock 大家应该都非常熟悉了,但这两个锁,作用域仅限制于单个Tomcat,如果使用了 Tomcat 集群,这两个锁就不管用了。

此时我们就要引入分布式锁了,分布式锁的实现方式有很多,可以使用 MySQL 数据库实现,也可以使用 ZookeePEr 实现,当然比较常用的还是使用 redis 实现。

今天我们就来聊一下基于 Redis 的实现方式 —— Redisson。

 

2. Redisson 在 SPRingboot 中的使用

2.1 引入依赖

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

 

2.2 在 Springboot 配置中配置Redis

支持 Redis单体、Redis哨兵模式 和 Redis集群模式

spring:
  redis:
    host: 192.168.1.12
    port: 6379
    password: zhuifengren

 

2.3 Demo代码

    @Autowired
    private RedissonClient redissonClient;

    public void lock() {

        RLock rLock = redissonClient.getLock("myLock");
        LOG.info("进入了方法");

        try {
            // 加锁,30秒后自动释放锁
            rLock.lock(30, TimeUnIT.SECONDS);
            log.info("获得了锁");

            Thread.sleep(15000);

        } catch (Exception ex) {
            log.error(ex.getMessage(), ex);
        } finally {
            // 释放锁
            rLock.unlock();
            log.info("释放了锁");
        }
    }

 

3. 综述

今天聊了一下 Springboot中使用Redisson实现分布式锁,希望可以对大家的工作有所帮助。

欢迎帮忙点赞、评论、转发、加关注 :)

关注追风人聊Java,每天更新Java干货。

 

脚本宝典总结

以上是脚本宝典为你收集整理的Springboot中使用Redisson实现分布式锁全部内容,希望文章能够帮你解决Springboot中使用Redisson实现分布式锁所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。