Redisson的红锁,分段锁,公平锁,联锁。。。。。。

红锁:Redisson红锁可以防止主从集群锁丢失问题。Redisson红锁要求,必须要构建至少三个Redis主从集群,若一个请求要申请锁,必须向所有主从集群中提交key写入请求,只有当大多数集群(过半集群)锁写入成功后,该锁才算申请成功

分段锁 :解决锁的串行化引发的性能问题,使访问并行化。将要共享访问的一个资源,拆分成多个共享资源,这样就会将一把锁的需求转变为多把锁,实现并行话

例如:对于秒杀商品sk:0008,共有1000件,现在将其拆分为10份,每份100件。即将秒杀商品变为了10件,分别为 sk:0008:01,sk:0008:02,sk:0008:03,...这样的话,就需要10把锁来控制所有请求的并发,由原来的因为只有一把锁而导致的每个时刻只能处理一个请求,变为了现在有了10把锁,每个时刻可以同时处理10个请求,并发提高10倍

可重入锁:Redisson的分布式锁RLock是一种可重入锁,当一个线程获取到锁之后,这个线程可以再次获取本对象上的锁,而其他线程不可以

公平锁:Redisson的可重入锁RLock默认是一种非公平锁,但也支持可重入公平锁FailLock。当有多个线程同时申请锁时,这些线程会进入到一个FIFO队列,只有队列首元素才能获取到锁,其他元素等待,只有当锁被释放后,才会再将锁分配给当前队列元素

联锁 Redisson分布式锁可以实现联锁MultiLock.当一个线程需要同时处理多个共享资源时,可以使用联锁,即一次申请多个锁,同时锁定多个共享资源。联锁可以预防死锁。相当于对共享资源的申请实现了原子性:要么都申请到,只要缺少一个资源,则将申请到的所有资源全部释放

红锁和联锁的区别是:红锁实现的是对一个共享资源的同步访问控制,而联锁实现的是多个共享资源的同步访问控制

读写锁:一个共享资源,在没有写锁的情况下,允许同时添加多个读锁,只要添加了写锁,任何读锁和写锁都不能再次添加,即读锁是共享锁,写锁为排他锁(和zookeeper的读写锁一致)

后边补充个知识点:
数据库缓存双写不一致问题怎么解决?

延迟双删(操作数据库数据--------》删除缓存----(延时)----》删除缓存)

使用读写锁(Redisson)

Zookeeper的读写锁

相关推荐
短剑重铸之日9 分钟前
《7天学会Redis》特别篇: Redis分布式锁
java·redis·分布式·后端·缓存·redission·看门狗机制
小北方城市网30 分钟前
SpringBoot 全局异常处理与接口规范实战:打造健壮可维护接口
java·spring boot·redis·后端·python·spring·缓存
Mr__Miss1 小时前
Redis网络模型
数据库·redis·面试
亲爱的非洲野猪1 小时前
Apigee Hybrid 数据存储架构详解:Redis与数据库的精确分工
数据库·redis·架构
不想写bug呀1 小时前
Redis基础知识及五种类型操作
数据库·redis·缓存
alonewolf_992 小时前
Redis7底层数据结构深度解析:从源码透视高性能设计精髓
数据结构·redis·分布式架构
万象.3 小时前
redis数据结构list的基本指令
数据结构·redis·list
難釋懷3 小时前
Redis桌面客户端
数据库·redis·缓存
填满你的记忆3 小时前
【从零开始——Redis 进化日志|Day5】分布式锁演进史:从 SETNX 到 Redisson 的完美蜕变
java·数据库·redis·分布式·缓存
hanqunfeng3 小时前
(四十)SpringBoot 集成 Redis
spring boot·redis·后端