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:禁止驱逐数据,这也是默认策略