Redisson 分布式锁源码 10:读写锁
2021-07-06 08:37:29Redisson 还支持可重入读写锁,允许在分布式场景下,同时有多个读锁和一个写锁处于加锁状态。
前言
Redisson 还支持可重入读写锁,允许在分布式场景下,同时有多个读锁和一个写锁处于加锁状态。
1、使用读写锁
Redisson 读写锁实现了 JUC 下的 readWriteLock,使用方式基本相同。
2、源码
加锁源码基本和之前的可重入锁加锁无区别,唯一的差异就是在 Lua 脚本这里。
所以下面着重分析 Lua 脚本。
读锁源码
源码地址:org.redisson.RedissonReadLock#tryLockInnerasync
参数列表:
首次加读锁
读锁重入
如果是重入的情况下:
读读支持
写读互斥
已经加了读锁了,此时写锁进来,不满足第一部分,也不满足第二部分,所以直接返回当前锁的剩余时间。
然后再 Java 代码中进行 while (true) 自旋等待。
通过上面可以看出,在读锁的时候:
写锁源码
源码地址:org.redisson.RedissonWriteLock#tryLockInnerAsync
参数列表:
写锁源码相对比较好理解:

这么下来,可以看出直接满足,写写互斥,读写互斥,当前线程又可以重入。
3、总结
到这里基本上读写锁就看完了,读锁实现的稍微复杂一些,写锁简单明了。
在读锁的时候:
在写锁的时候:
至于看门狗,这些都和之前的一样,就不额外介绍了。
发表评论