Redisson 分布式锁源码之八:MultiLock 加锁与锁释放

开发 前端 分布式 Redis
基于 Redis 的 Redisson 分布式联锁 RedissonMultiLock 对象可以将多个 RLock 对象关联为一个联锁,每个 RLock 对象实例可以来自于不同的 Redisson 实例。

[[409055]]

前言

基于 Redis 的 Redisson 分布式联锁 RedissonMultiLock 对象可以将多个 RLock 对象关联为一个联锁,每个 RLock 对象实例可以来自于不同的 Redisson 实例。

当然,这是官网的介绍,具体是什么?一起看看联锁 MultiLock 使用以及源码吧!

1MultiLock 使用

按照官方文档的说法,这里 Redisson 客户端可以不是同一个。当然,一般工作中也不会说不用一个客户端吧。

2加锁

在阅读 MultiLock 加锁之前,小伙伴应该已经阅读过普通加锁的相关文章。

源码入口:org.redisson.RedissonMultiLock#lock()

默认超时时间 leaseTime 没有设置,所以为 -1。

这块方法太长,咱们拆分进行阅读。

  1. 基础等待时间 baseWaitTime = 锁数量 * 1500,在这里就是 4500 毫秒;
  2. leaseTime == -1 所以 waitTime = baseWaitTime,也就是 4500;
  3. while (true) 调用 tryLock 加锁,直到成功。

调用 tryLock 方法,其中参数 waitTime = 4500,leaseTime = -1,unit = MILLISECONDS。

下面看一下 tryLock 里面有什么逻辑?

leaseTime != -1 不满足,这部分直接跳过。

waitTime != -1 条件满足,remainTime = 4500,lockWaitTime = 4500。

所以,failedLocksLimit() 这个方法直接返回 0,就是必须全部加锁成功。

这里才是重点:

遍历所有的锁,依次加锁。

加锁逻辑就和可重入锁加锁并无区别了。所以 Lua 脚本就不进行分析了。

上面就是 tryLock 加锁之后的结果。

加锁成功,则将成功的锁放进 acquiredLocks 集合中;

加锁失败,需要判断 failedLocksLimit,因为这里是 0,所以会直接对成功加锁集合 acquiredLocks 中的所有锁执行锁释放,同时清空成功集合,恢复迭代器。

每次加锁之后,会更新锁剩余时间 remainTime,如果 remainTime 小于等于 0 了,则说明加锁超时,直接返回 false。

这样就会执行外部的 while (true) 逻辑,然后重新再走一遍 RedissonMultiLock#tryLock。

3锁释放

看完加锁逻辑,锁释放就更容易理解了。

直接遍历释放锁即可,lock.unlockAsync() 是调用的 RedissonBaseLock#unlockAsync() 方法。

4总结

根据我的理解,画图如下:

 

总体而言,就是将 key1、key2、key3 …… keyN 放到一个 List 集合中,然后迭代循环加锁,直到所有的都成功。解锁的时候就是再遍历锁进行释放锁。

本文转载自微信公众号「程序员小航」,可以通过以下二维码关注。转载本文请联系程序员小航公众号。

 

责任编辑:武晓燕 来源: 程序员小航
相关推荐

2021-06-30 14:56:12

Redisson分布式公平锁

2021-07-02 08:51:09

Redisson分布式锁公平锁

2021-07-01 09:42:08

Redisson分布式

2021-06-27 21:24:55

RedissonJava数据

2021-07-06 08:37:29

Redisson分布式

2021-07-09 06:48:31

ZooKeeperCurator源码

2022-08-04 08:45:50

Redisson分布式锁工具

2022-06-30 08:04:16

Redis分布式锁Redisson

2021-07-07 07:09:49

Redisson分布式锁源码

2021-07-10 10:02:30

ZooKeeperCurator并发

2021-06-28 10:51:55

Redisson分布式锁Watchdog

2024-01-02 13:15:00

分布式锁RedissonRedis

2021-07-16 07:57:34

ZooKeeperCurator源码

2023-08-27 22:13:59

Redisson分布式缓存

2021-09-17 07:51:24

RedissonRedis分布式

2018-07-17 08:14:22

分布式分布式锁方位

2018-11-27 16:17:13

分布式Tomcat

2021-11-26 06:43:19

Java分布式

2021-07-08 09:21:17

ZooKeeper分布式锁 Curator

2019-06-19 15:40:06

分布式锁RedisJava
点赞
收藏

51CTO技术栈公众号