您现在的位置是:亿华云 > 人工智能
Redisson 分布式锁源码 10:读写锁
亿华云2025-10-09 13:05:12【人工智能】6人已围观
简介前言Redisson 还支持可重入读写锁,允许在分布式场景下,同时有多个读锁和一个写锁处于加锁状态。1、使用读写锁Redisson 读写锁实现了 JUC 下的 ReadWriteLock,使用方式基本
前言
Redisson 还支持可重入读写锁,分布允许在分布式场景下,式锁锁同时有多个读锁和一个写锁处于加锁状态。源码
1、读写使用读写锁
Redisson 读写锁实现了 JUC 下的分布 ReadWriteLock,使用方式基本相同。式锁锁
2、源码源码
加锁源码基本和之前的读写可重入锁加锁无区别,唯一的分布差异就是在 Lua 脚本这里。
所以下面着重分析 Lua 脚本。式锁锁
读锁源码
源码地址:org.redisson.RedissonReadLock#tryLockInnerAsync
参数列表:
KEYS[1]:锁名字 anyRWLock KEYS[2]:锁超时 key { 锁名字}:UUID:ThreadId:rwlock_timeout 组成的源码字符串,{ anyRWLock}:e70b1307-9ddd-43de-ac9d-9c42b5c99a0d:1:rwlock_timeout ARGV[1]:锁时间,读写默认 30s ARGV[2]:当前线程,分布UUID:ThreadId 组成的式锁锁字符串,e70b1307-9ddd-43de-ac9d-9c42b5c99a0d:1 ARGV[3]:写锁名字,源码getWriteLockName(threadId) 写锁名字,UUID:ThreadId:write 组成的字符串, e70b1307-9ddd-43de-ac9d-9c42b5c99a0d:1:write首次加读锁
读锁重入
如果是重入的情况下:
锁存在,且是读锁,直接进入第二部分 对锁 anyRWLock 的 e70b1307-9ddd-43de-ac9d-9c42b5c99a0d:1(当前线程)值自增 1 表是重入 再创建 { anyRWLock}:e70b1307-9ddd-43de-ac9d-9c42b5c99a0d:1:rwlock_timeout:2 表示第二次加锁的超时时间读读支持
写读互斥
已经加了读锁了,此时写锁进来,不满足第一部分,也不满足第二部分,所以直接返回当前锁的剩余时间。
然后再 Java 代码中进行 while (true) 自旋等待。
通过上面可以看出,在读锁的时候:
锁 anyRWLock 是哈希表结构的 加锁时,会对哈希表设置 mode 字段来表示这个锁是读锁还是写锁,mode = read 表示读锁 加锁时,会对哈希表设置当前线程 anyRWLock 的 UUID:ThreadId 字段,云服务器提供商值表示重入次数 每次加锁,会额外维护一个 key 表示这次锁的超时时间,这个 key 的结构是 { 锁名字}:UUID:ThreadId:rwlock_timeout:重入次数写锁源码
源码地址:org.redisson.RedissonWriteLock#tryLockInnerAsync
参数列表:
KEYS[1]:当前锁 anyRWLock ARGV[1]:锁时间,默认 30s ARGV[2]:写锁名字,UUID:ThreadId:write 组成的字符串,c69a9ed4-5c30-4952-814e-c0b94ad03a7f:1:write写锁源码相对比较好理解:
判断锁的模式,是写锁 锁不存在直接创建 锁存在,再判断是不是自己,是自己则重入这么下来,可以看出直接满足,写写互斥,读写互斥,当前线程又可以重入。
3、总结
到这里基本上读写锁就看完了,读锁实现的稍微复杂一些,写锁简单明了。
在读锁的时候:
锁 anyRWLock 是哈希表结构 加锁时,会对哈希表设置 mode 字段来表示这个锁是读锁还是写锁,香港云服务器mode = read 表示读锁 加锁时,会对哈希表设置当前线程 anyRWLock 的 UUID:ThreadId 字段,值表示重入次数 每次加锁,会额外维护一个 key 表示这次锁的超时时间,这个 key 的结构是 { 锁名字}:UUID:ThreadId:rwlock_timeout:重入次数在写锁的时候:
锁 anyRWLock 是哈希表结构 加锁时,会对哈希表设置 mode 字段来表示这个锁是读锁还是写锁,mode = write 表示写锁 在 anyRWLock 中再额外维护一个字段 UUID:ThreadId:write 表示重入次数 至于看门狗,这些都和之前的一样,就不额外介绍了。 本文转载自微信公众号「程序员小航」,可以通过以下二维码关注。转载本文请联系程序员小航公众号。很赞哦!(1238)
相关文章
- 公司在注册域名时还需要确保邮箱的安全性。如果邮箱不安全,它只会受到攻击。攻击者可以直接在邮箱中重置密码并攻击用户。因此,有必要注意邮箱的安全性。
- Java编程内功-数据结构与算法「线索化二叉树」
- 看完这个“秒杀”设计方案!我有点慌了
- AnnotationAwareAspectJAutoProxyCreator类是干嘛的?
- 在众多公司中,如果我们必须选择一家可信的公司,那当然是信得过的。
- Python 怎么捕获警告?(注意:不是捕获异常)
- 字节跳动最爱考的前端面试题:计算机网络基础
- 为何DevOps是如今重要的技术策略
- 公司和个人选域名方法一样吗?有什么不同?
- 微软与Brilliant.org合作推出量子计算课程 围绕Q#编程教学