Redisson 分布式锁源码 08:MultiLock 加锁与锁释放
前言#
基于 Redis 的 Redisson 分布式联锁 RedissonMultiLock 对象可以将多个 RLock 对象关联为一个联锁,每个 RLock 对象实例可以来自于不同的 Redisson 实例。
当然,这是官网的介绍,具体是什么?一起看看联锁 MultiLock 使用以及源码吧!
MultiLock 使用#
按照官方文档的说法,这里 Redisson 客户端可以不是同一个。当然,一般工作中也不会说不用一个客户端吧。
加锁#
在阅读 MultiLock 加锁之前,小伙伴应该已经阅读过普通加锁的相关文章。
源码入口:org.redisson.RedissonMultiLock#lock()
默认超时时间 leaseTime 没有设置,所以为 -1。
这块方法太长,咱们拆分进行阅读。
- 基础等待时间 baseWaitTime = 锁数量 * 1500,在这里就是 4500 毫秒;
leaseTime == -1
所以 waitTime = baseWaitTime,也就是 4500;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
。
锁释放#
看完加锁逻辑,锁释放就更容易理解了。
直接遍历释放锁即可,lock.unlockAsync()
是调用的 RedissonBaseLock#unlockAsync()
方法。
总结#
根据我的理解,画图如下:
总体而言,就是将 key1、key2、key3 …… keyN 放到一个 List 集合中,然后迭代循环加锁,直到所有的都成功。解锁的时候就是再遍历锁进行释放锁。
相关推荐#
作者:程序员小航
出处:https://www.cnblogs.com/liuzhihang/p/14993186.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
欢迎关注个人公众号:『 程序员小航 』
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!