Redis分布式锁

Redis分布式锁

Redis实现分布式锁主要利用Redis的setnx命令。setnx是SET if not exists(如果不存在,则 SET)的简写。

127.0.0.1:6379> setnx test:lock 1 #在 test:lock 不存在的情况下,赋值(加锁)
(integer) 1
127.0.0.1:6379> get test:lock  #获取 test:lock 的value值
"1"
127.0.0.1:6379> setnx test:lock 2 #试图覆盖tets:lock的值
(integer) 0
127.0.0.1:6379> get test:lock #覆盖失败
"1"
127.0.0.1:6379> del test:lock#删除key值
(integer) 1
127.0.0.1:6379> setnx test:lock 2 #再次设置key值
(integer) 1
127.0.0.1:6379> get test:lock #设置成功
"2"

在这里插入图片描述

以上就是redis分布式锁一些基本的实现命令。

但如果只是这样简单的操作可能会遇到一些问题

1.客服端A宕机,造成死锁

这个问题很好解决,只要给锁加上过期时间就好了。
在这里插入图片描述
以上解决了客户端宕机的问题,但如果有效期到了,有客户端代码还没执行完呢?

比较靠谱的方法是给锁续期。使用watchDog机制实现锁的续期。当加锁成功后,同时开启守护线程,默认有效期是30秒,每隔10秒就会给锁续期到30秒,只要持有锁的客户端没有宕机,就能保证一直持有锁,直到业务代码执行完毕由客户端自己解锁,如果宕机了自然就在有效期失效后自动解锁。

内容淘汰策略

定期删除与惰性删除

定期删除,指的是redis默认是每隔100ms就随机抽取一些设置了过期时间的key,检查其是否过期,如果过期就删除

惰性删除,获取某个key的时候,redis会检查一下 ,这个key如果设置了过期时间那么是否过期了?如果过期了此时就会删除,不会给你返回任何东西。

在这里插入图片描述

Random策略

volatile-random:从已设置过期时间的数据集中任意选择数据淘汰。
allkeys-random:从数据集(server.db[i].dict)中任意选择数据淘汰

Lru策略

在这里插入图片描述

volatile-lru:从已设置过期时间的数据集中挑选最近最少使用的数据淘汰。
allkeys-lru:从数据集中挑选最近最少使用的数据淘汰

Lfu策略

volatile-lfu:从已设置过期时间的数据集挑选使用频率最低的数据淘汰。
allkeys-lfu:从数据集中挑选使用频率最低的数据淘汰。

Ttl策略

volatile-ttl:从已设置过期时间的数据集中挑选将要过期的数据淘汰。

no-enviction

no-enviction:禁止驱逐数据,这也是默认策略

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值