Redis:普通锁和分布式锁实现原理

Redis:普通锁和分布式锁实现原理

一、Redis单服务实例实现锁
1、实现锁有以下要求:

(1)唯一性:一把锁只能存在一个实例;
(2)无死锁:client操作超时自动释放;
(3)安全性:只对当前client可操作;
唯一性:同一把锁有切只能有一个实例;假如A、B两个client同时有Lock这把锁,A和B都有权限同时操作同一数据,那“锁”也就没有了意义,锁存在的意义就是避免同步操作;
无死锁:client-A在获取Lock这把锁之后,client-A意外退出(网络超时、程序卡死等),在退出之前没有对锁释放(可能都来不及释放),这个时候Lock这把锁就长期持有,在client-A重新登录之后,如果无法获取“Lock”都可能无法释放锁,Redis通过Lock的过期时间控制锁的自动释放;
安全性:如果client-A在获取Lock锁之后,client-B也可以对Lock进行操作的话,最后判定Lock锁解锁失败(redis在删除一个不存在的key时,会返回失败,如下代码所示);

$> del UserInfo{112001}
(integer) 0

2、单例锁实现

基于以上三个特性,Redis通过SET命令实现锁的创建和删除,如下示例:

 SET resource_name my_random_value NX PX 30000

resource_name:锁的名字,在Redis中做key;
my_random_value:锁的值,如果不要求安全性时,可以不操作该值,只需要设置上值即可;如果需要保证安全性,此值在所有客户端和所有锁定请求中必须唯一,可以通过秒级时间戳来保证值得唯一,或者连接CLIENT ID。
NX:SET命令的参数,如果Key存在,则SET失败,保证锁的唯一性;
PX:SET命令的参数,设置成功之后,在30000毫秒内将过期,保证无死锁;

为什么可以通过VALUE随机值来保证安全性ÿ

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis自带分布式是基于Redis普通命令实现的。为了更好地理解Redis自带分布式,我们需要先了解与分布式相关的普通Redis命令。只有充分了解这些命令,才能更好地理解高级的Redis分布式实现,因为高级的分布式实现完全基于普通Redis命令。 在Redis中,分布式实现原理其实很简单,它基于RedLock思想。具体实现过程是遍历所有的Redis客户端,然后依次对它们进行加操作。最后统计成功的次数来判断是否加成功。 需要注意的是,Redis自带的分布式也有性能瓶颈问题。在高并发情况下,如果同时有多个客户端请求加,可能会导致性能下降。为了解决这个问题,可以采用Redis分段的方式,将分为多个段,每个段有自己的。这样可以提高并发性能。 除了Redis自带的分布式分布式实现还有其他方式,比如基于文件、数据库、以及基于ZooKeeper的分布式等。具体选择哪种方式取决于具体的应用场景和需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Redis分布式(图解 - 秒懂 - 史上最全)](https://blog.csdn.net/crazymakercircle/article/details/116425814)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值