0
点赞
收藏
分享

微信扫一扫

分布式锁2:基于redis实现分布式锁

回望这一段人生 2023-10-13 阅读 91

一 redis实现分布式锁

1.1 原理

setnx+expire+del  命令实现redis的分布式锁;其中 setnx  不存在则新增;存在则忽略。即先用setnx来抢锁,如果抢到之后,再用expire给锁设置一个过期时间,防止锁忘记了释放。例如:

setnx  lock   111  ex  20 nx

但是如果expire无法执行, 会导致死锁,redis中setnx+expire是非原子操作, 除了用LUA脚本保证实现原子操作, 其实可以直接使用redis自带的set方法直接实现.

举报

相关推荐

0 条评论