redis的setnx实现分布式锁

embedded/2024/9/23 1:36:52/

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 秒后自动释放。


http://www.ppmy.cn/embedded/58270.html

相关文章

htmlcss基础

html 组成 <!--跟标签--> <html><!--头标签--><head><!--网页的标题标签--><tltle>测试html</title></head><!--体标签--><body><font color"yellow" size"7">测试体</font>&l…

Qt提升控件失败的解决办法

在 Qt Creator 中&#xff0c;通常是可以通过继承已有的类来创建新的子类的。如果您想要将 QGraphicsView 提升为新建的子类&#xff0c;可以按照以下步骤进行操作&#xff1a; 打开 Qt Creator&#xff0c;并打开您的项目。打开包含 QGraphicsView 的头文件&#xff08;例如 …

开源数据科学平台Anaconda简介

开源数据科学平台Anaconda简介 零、时光宝盒 最近&#xff0c;某金融行业女性选择以跳楼的形式结束自己的生命&#xff0c;这件不幸的事情成了热门话题&#xff0c;各种猜测的都有&#xff0c;有些人评论的话真的很过分。我想起前段时间看到的&#xff0c;有个女学生跳江&#…

k8s-第二节-常用操作

k8s命令行常用操作 k8s命令行 操作对象时都要前面声明操作对象类型 kubectl get kubectl describe kubectl delete kubectl edit kubectl logs kubectl exec kubectl port-forward 端口转发将pod 端口映射出来 kubectl cp 本地文件路径:容器文件路径 kubectl apply …

系统架构师考点--信息系统基础知识

大家好。今天我们来总结一下信息系统基础知识的相关考点&#xff0c;每年都会考&#xff0c;一般是在上午场选择题中&#xff0c;占3分左右&#xff0c;其次下午场论文也有可能会出相关的考题。 一、信息系统概述 信息系统&#xff1a; 是由计算机硬件、网络和通信设备、计算…

MATLAB 2024b 更新了些什么?

MATLAB 2024b版本已经推出了预览版&#xff0c;本期介绍一些MATLAB部分的主要的更新内容。 帮助浏览器被移除 在此前的版本&#xff0c;当我们从MATLAB中访问帮助文档时&#xff0c;默认会通过MATLAB的帮助浏览器&#xff08;Help browser&#xff09;。 2024b版本开始&…

【前端从入门到精通:第二课:HTML头部标签常用标签】

走进HTML世界 HTML简介 可参考百度百科 学习变成到底难不难&#xff1f; A. 1 * 5 ? B. 111 * 555 ? A 到 B的过程&#xff0c; 差距就在于动手&#xff0c;不动手你就学不会。 如何创建HTML文件 ​鼠标右键->新建文本文件->更改后缀名.html 创建文件所需要注…

【SOM神经网络的数据分类】SOM神经网络的数据分类的一个小案例

【SOM神经网络的数据分类】SOM神经网络的数据分类的一个小案例 注&#xff1a;本文仅作为自己的学习记录以备以后复习查阅 一 概述 自组织特征映射网络&#xff08;Self-Organizing Feature Map, SOM&#xff09;也叫做Kohonen网络&#xff0c;它的特点是&#xff1a;全连接、…