当前位置:   article > 正文

Springboot 整合 Redisson_redisson-spring-boot-starter exclusions

redisson-spring-boot-starter exclusions

一、引入对应包

除redis相关包外额外引入下面的包:

<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson-spring-boot-starter</artifactId>
    <version>3.13.1</version>
</dependency>
  • 1
  • 2
  • 3
  • 4
  • 5

版本对应关系:

在这里插入图片描述
按上图说明,如果是springboot 2.1.X 应该如下引入

<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson-spring-boot-starter</artifactId>
    <version>3.13.1</version>
    <exclusions>
        <exclusion>
            <groupId>org.redisson</groupId>
            <artifactId>redisson-spring-data-22</artifactId>
        </exclusion>
    </exclusions>
</dependency>

<dependency>
    <groupId>org.redisson</groupId>
    <!-- for Spring Data Redis v.2.1.x -->
    <artifactId>redisson-spring-data-21</artifactId>
    <version>3.13.1</version>
</dependency>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

二、使用方法:

@Service
@Slf4j
public class DemoService {
    @Autowired
    private RedissonClient redissonClient;

    public void redissonTest(){
        //创建锁
        RLock helloLock = redissonClient.getLock("hello");
        log.info(" start lock time:"+System.currentTimeMillis());
        try {
            //20s拿不到锁,返回false; 拿到锁最多持有8s
            boolean res = helloLock.tryLock(20,8, TimeUnit.SECONDS);
            if ( res){
                log.info("locked time:"+System.currentTimeMillis());
            }else{
                System.out.println("系统繁忙");
            }
        }catch (Exception e){
            e.printStackTrace();
            //实际业务中用到事务的需要手动处理
//          TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
        } finally {
            //释放锁
            log.info("------finished-------");
            helloLock.unlock();
        }
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29

三、基本原理

在这里插入图片描述
Redis分布式锁的缺点
如果对某个redis master实例,写入了myLock这种锁key的value,此时会异步复制给对应的master slave实例。
但是这个过程中一旦发生redis master宕机,主备切换,redis slave变为了redis master。
接着就会导致,客户端2来尝试加锁的时候,在新的redis master上完成了加锁,而客户端1也以为自己成功加了锁。
此时就会导致多个客户端对一个分布式锁完成了加锁。
这时系统在业务语义上一定会出现问题,导致各种脏数据的产生。
所以这个就是redis cluster,或者是redis master-slave架构的主从异步复制导致的redis分布式锁的最大缺陷:在redis master实例宕机的时候,可能导致多个客户端同时完成加锁。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/815217
推荐阅读
相关标签
  

闽ICP备14008679号