13518219792

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

Redisson 分布式锁源码 10:读写锁

Redisson 分布式锁源码 10:读写锁

作者:程序员小航 2021-07-06 08:37:29

开发

前端

分布式

Redis Redisson 还支持可重入读写锁,允许在分布式场景下,同时有多个读锁和一个写锁处于加锁状态。

成都创新互联主要从事网站设计、网站制作、网页设计、企业做网站、公司建网站等业务。立足成都服务台山,十载网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18980820575

前言

Redisson 还支持可重入读写锁,允许在分布式场景下,同时有多个读锁和一个写锁处于加锁状态。

1、使用读写锁

Redisson 读写锁实现了 JUC 下的 ReadWriteLock,使用方式基本相同。

2、源码

加锁源码基本和之前的可重入锁加锁无区别,唯一的差异就是在 Lua 脚本这里。

所以下面着重分析 Lua 脚本。

读锁源码

源码地址:org.redisson.RedissonReadLock#tryLockInnerAsync

参数列表:

首次加读锁

读锁重入

如果是重入的情况下:

读读支持

写读互斥

已经加了读锁了,此时写锁进来,不满足第一部分,也不满足第二部分,所以直接返回当前锁的剩余时间。

然后再 Java 代码中进行 while (true) 自旋等待。

通过上面可以看出,在读锁的时候:

写锁源码

源码地址:org.redisson.RedissonWriteLock#tryLockInnerAsync

参数列表:

写锁源码相对比较好理解:

这么下来,可以看出直接满足,写写互斥,读写互斥,当前线程又可以重入。

3、总结

到这里基本上读写锁就看完了,读锁实现的稍微复杂一些,写锁简单明了。

在读锁的时候:

在写锁的时候:

至于看门狗,这些都和之前的一样,就不额外介绍了。
本文转载自微信公众号「程序员小航」,可以通过以下二维码关注。转载本文请联系程序员小航公众号。


新闻标题:Redisson 分布式锁源码 10:读写锁
转载注明:http://cdbrznjsb.com/article/cdjodjs.html

其他资讯

让你的专属顾问为你服务