redis的setnx实现分布式锁

SETNX 是 Redis 提供的一个原子(atomic)操作命令,用于设置一个 key 及其对应的 value,如果并且仅当该 key 不存在。如果 key 已经存在,SETNX 命令不会执行任何操作。

Redis 的 SETNX 命令的底层原理建立在 Redis 单线程的事件驱动模型上。这意味着 Redis 用单个线程按顺序执行所有命令,这使得每个命令都是原子性的。当一个 SETNX 命令被发出时,Redis 服务器会对 key-value 存储结构进行以下操作:

检查 key 是否存在:

Redis 首先检查 key 是否在当前数据库的 key-space 中存在。因为操作是在单个线程中顺序执行的,所以不存在并发问题。

设置值:

如果 key 不存在,Redis 将为该 key 创建一个新的条目,并设置提供的 value。整个操作从开始到结束是连续执行的,所以不会有其他操作跟这个操作冲突。

返回结果:

如果 key 被成功设置,Redis 返回 1如果 key 已经存在,那么 SETNX 将不做任何改变,并返回 0

需要注意的是,SETNX 本身并不具备锁的超时能力,可能会导致死锁的情况发生(例如,持有锁的进程意外终止而没能释放锁)。因此在 Redis 2.6.12 版本之后,推荐使用 SET 命令结合 NX 和 PX毫秒(或 EX秒)选项,来同时设置键的值和过期时间,从而得到一个更健壮的锁行为:

SET lock_key unique_lock_value NX PX 30000

这个命令尝试设置一个 key,并且设置 30 秒的过期时间,保证即使锁的持有者在未能释放锁的情况下崩溃,锁也会在 30 秒后自动释放。

相关推荐
真正的醒悟15 小时前
什么是安全设备组网
服务器·数据库·php
小哈里15 小时前
【软考架构】2025H2系统架构设计师考试复习.jpg(软件架构、软件工程、数据库、Web开发、高项)
数据库·架构·系统架构·软件工程·后端开发
B站_计算机毕业设计之家15 小时前
深度学习:Yolo水果检测识别系统 深度学习算法 pyqt界面 训练集测试集 深度学习 数据库 大数据 (建议收藏)✅
数据库·人工智能·python·深度学习·算法·yolo·pyqt
wei_shuo18 小时前
全场景自动化 Replay 技术:金仓 KReplay 如何攻克数据库迁移 “难验证“ 难题
数据库·自动化·king base
葡萄城技术团队18 小时前
打破误解!MongoDB 事务隔离级别深度实测:快照隔离竟能防住 8 种异常?
数据库
Gold Steps.18 小时前
数据库正常运行但是端口变成了0?
数据库·mysql
大数据CLUB18 小时前
酒店预订数据分析及预测可视化
大数据·hadoop·分布式·数据挖掘·数据分析·spark·mapreduce
驾驭人生18 小时前
Docker中安装 redis、rabbitmq、MySQL、es、 mongodb设置用户名密码
redis·docker·rabbitmq
杂亿稿18 小时前
增删改查操作
数据库
Code_Geo18 小时前
在postgres数据库中Postgres FDW 全面详解
数据库·fdw