详细解释Redis的SET NX命令

详细解释Redis的SET NX命令

SET NX 命令是 Redis 中用于实现分布式锁的一个重要命令。它的语法和用法如下:

SET key value NX [EX seconds | PX milliseconds]

参数解释

  • key:要设置的键名。
  • value:要设置的键值,通常用一个唯一标识符(如 UUID)来标识持有锁的客户端。
  • NX:表示只有在键不存在时才执行 SET 操作。NX 是 “Not eXists” 的缩写。
  • EX seconds:可选参数,设置键的过期时间,以秒为单位。
  • PX milliseconds:可选参数,设置键的过期时间,以毫秒为单位。

命令功能

SET NX 命令用于在 Redis 中原子性地设置一个键值对,并且只有在该键不存在时才会进行设置。它结合 EXPX 参数,可以实现一个具有过期时间的分布式锁。

使用场景

SET NX 命令通常用于实现分布式锁,以确保在分布式环境中,同一时间只有一个客户端可以持有锁,从而避免并发访问导致的数据不一致问题。

举例说明

假设我们有一个需要加锁的资源,使用 SET NX 命令实现分布式锁的过程如下:

import redis.clients.jedis.Jedis;
import java.util.UUID;

public class DistributedLock {

    private Jedis jedis;
    private String lockKey;
    private String lockValue;
    private int expireTime;

    public DistributedLock(Jedis jedis, String lockKey, int expireTime) {
        this.jedis = jedis;
        this.lockKey = lockKey;
        this.expireTime = expireTime;
    }

    // 获取锁
    public boolean acquireLock() {
        this.lockValue = UUID.randomUUID().toString();
        String result = jedis.set(lockKey, lockValue, "NX", "EX", expireTime);
        return "OK".equals(result);
    }

    // 释放锁
    public boolean releaseLock() {
        String luaScript = 
            "if redis.call('get', KEYS[1]) == ARGV[1] then " +
            "return redis.call('del', KEYS[1]) " +
            "else " +
            "return 0 " +
            "end";
        Object result = jedis.eval(luaScript, 1, lockKey, lockValue);
        return result.equals(1L);
    }

    public static void main(String[] args) {
        Jedis jedis = new Jedis("localhost", 6379);
        DistributedLock lock = new DistributedLock(jedis, "resource_lock", 10);

        if (lock.acquireLock()) {
            try {
                System.out.println("Lock acquired, doing some work...");
                // 执行业务逻辑
            } finally {
                lock.releaseLock();
                System.out.println("Lock released");
            }
        } else {
            System.out.println("Failed to acquire lock");
        }

        jedis.close();
    }
}

解释示例代码

  1. 获取锁

    • lockValue:生成一个唯一标识符,作为锁的值。
    • jedis.set(lockKey, lockValue, "NX", "EX", expireTime):尝试使用 SET NX 命令设置锁。只有在 lockKey 不存在时,才能成功设置该键,并指定过期时间 expireTime
  2. 释放锁

    • 释放锁时需要确保只有锁的持有者才能释放锁。使用 Lua 脚本保证原子性:
      if redis.call('get', KEYS[1]) == ARGV[1] then 
      return redis.call('del', KEYS[1]) 
      else 
      return 0 
      end
      
    • 脚本首先检查 lockKey 的值是否等于 lockValue,如果相等,则删除该键,否则不执行任何操作。

注意事项

  • 唯一标识符:使用唯一标识符来标识每个持有锁的客户端,防止锁被错误释放。
  • 过期时间:设置合理的过期时间,防止死锁。如果客户端在持有锁期间崩溃,过期时间可以自动释放锁。
  • 重试机制:获取锁时可以设置重试机制,防止短暂的争用导致获取锁失败。

通过 SET NX 命令,可以有效实现分布式锁,保证分布式环境中资源的安全访问和数据的一致性。

参考链接

  • Redis SET 命令:SET – Redis 命令参考
  • Redis 分布式锁:Distributed locks with Redis

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/758291.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

什么是无头浏览器?

简而言之,无头浏览器是没有图形用户界面 (GUI) 的 Web 浏览器。GUI 包括用户与之交互的数字元素,例如按钮、图标和窗口。但是,关于无头浏览器,您需要了解的还有很多。 在本文中,您将了解什么是…

2007-2022年 省级-绿色农业合作社数量相关数据整理

绿色农业合作社作为一种推动农业可持续发展的组织形式,对于促进环境保护、提高农产品质量和增加农民收入等方面具有重要作用。以下是对省级绿色农业合作社数量相关数据的介绍: 数据简介 定义:绿色农业合作社是由农民、农业专家、企业家等组…

关于Redisson分布式锁的用法

关于Redisson分布式锁的用法 Redisson是一个基于Redis的Java分布式对象和服务框架,它提供了多种分布式锁的实现,包括可重入锁、公平锁、读写锁等。Redisson实现分布式锁的核心原理主要依赖于Redis的数据结构和Redisson框架提供的高级功能。以下详细讲解…

基于RK3588的GMSL、FPDLink 、VByone及MIPI等多种摄像模组,适用于车载、机器人工业图像识别领域

机器人&工业摄像头 针对机器人视觉与工业检测视觉,信迈自主研发和生产GMSL、FPDLink 、VByone及MIPI等多种摄像模组,并为不同应用场景提供多种视场角度和镜头。拥有资深的图像算法和图像ISP专家团队,能够在软件驱动层开发、ISP算法、FPG…

sql-语句

文章目录 SQL语句的学习sql是什么sql的内置命令sql的种类sql mode库,表属性介绍:字符集,存储引擎列的数据类型:数字,字符串,时间列的约束DDL: 数据定义语言库表 Online DDL(ALGORITHM) *DML :数据操纵语言资…

算法:链表

目录 链表的技巧和操作总结 常用技巧: 链表中的常用操作 题目一:反转一个单链表 题目二:链表的中间结点 题目三:返回倒数第k个结点 题目四:合并两个有序链表 题目五:移除链表元素 题目六&#xff…

033基于SSM+Jsp的多用户博客个人网站

开发语言:Java框架:ssm技术:JSPJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包…

GPIO和PIN

文章目录 1 GPIO和Pin1.1 GPIO和Pin基础概念1.2 GPIO输入模式1.3 GPIO输出模式1.4 GPIO的HAL库1.4.1 一些HAL库表示1.4.2 HAL库常用GPIO函数1.4.3 GPIO点亮led灯程序例子 1 GPIO和Pin 1.1 GPIO和Pin基础概念 ​ 单片机有很多的引脚,为了操控每一个引脚&#xff0c…

JVM原理(四):JVM垃圾收集算法与分代收集理论

从如何判定消亡的角度出发,垃圾收集算法可以划分为“引用计数式垃圾收集”和“追踪式垃圾收集”两大类。 本文主要介绍的是追踪式垃圾收集。 1. 分代收集理论 当代垃圾收集器大多遵循“分代收集”的理论进行设计,它建立在两个假说之上: 弱分…

Git企业开发---初识Git

顾得泉:个人主页 个人专栏:《Linux操作系统》 《C从入门到精通》 《LeedCode刷题》 键盘敲烂,年薪百万! 引言 不知道大家有没有经历这种困惑,当我们要去交某文档时,总是要进行修改,修改后再交…

【知识学习】Unity3D中Shader Graph的概念及使用方法示例

Unity3D中的Shader Graph是一个强大的可视化Shader编辑工具,它允许用户通过拖拽和连接节点的方式来创建Shader,而不是通过传统的编写代码的方式。Shader Graph使得Shader的创建过程更加直观和易于理解,特别是对于那些不熟悉Shader语言编程的美…

19.《C语言》——【如何理解static和extern?】

🎇开场语 亲爱的读者,大家好!我是一名正在学习编程的高校生。在这个博客里,我将和大家一起探讨编程技巧、分享实用工具,并交流学习心得。希望通过我的博客,你能学到有用的知识,提高自己的技能&a…

MDA管理层讨论与分析内容信息披露情感分析数据(2010-2022年)

数据简介:MD&A通常是指管理层讨论与分析(Management Discussion & Analysis),是上市公司年报中一个重要的部分,主要包含公司经营业绩的讨论,以及未来前景的预测等。MD&A可以帮助投资者更好地理…

leetcode 第133场双周赛 100333.统计逆序对的数目【计数dp/滚动数组/前缀和优化】

分析: 先考虑如下问题。 求长度为n,逆序对为m的排列数量。 可以考虑dp,dp[i][j]定义为长度为i,逆序对为j的排列数量。 dp[1][0] 1; //枚举排列长度,或者认为枚举当前需要插到长度为i-1的排列中的数字 for(int i 1…

笔记本电脑安装CentOS

正文共:1234 字 24 图,预估阅读时间:2 分钟 前面我们对VPP进行了多次介绍(羡慕!大佬的VPP能达到180G性能,而我的却只有13.5G),可以发现他的很多优点,但是我们也可以发现它…

socket编程常见操作

1、连接的建立 分为两种:服务端处理接收客户端的连接;服务端作为客户端连接第三方服务 //作为服务端 int listenfd socket(AF_INET, SOCK_STREAM, 0); bind(listenfd, (struct sockaddr*)&servaddr, sizeof(servaddr))) listen(listenfd, 10); //…

【单片机毕业设计11-基于stm32c8t6的智能水质检测】

【单片机毕业设计11-基于stm32c8t6的智能水质检测】 前言一、功能介绍二、硬件部分三、软件部分总结 前言 🔥这里是小殷学长,单片机毕业设计篇11基于stm32的智能水质检测系统 🧿创作不易,拒绝白嫖可私 一、功能介绍 -------------…

武汉星起航:亚马逊欧洲站潮流指南,满足年轻人选品需求

在充满活力的20-30岁年龄段,年轻人们充满朝气,追求时尚与品质,对生活充满无限期待。亚马逊欧洲站作为全球领先的电商平台,为这一年龄段的人群提供了丰富多样的商品选择。武汉星起航将为您介绍亚马逊欧洲站针对20-30岁人群的选品攻…

三元表达式解析器

题意:其实本质上就是三目运算 ,只不过跟我们以往的三目运算不同的是,这一系列的运算可以把T 和 F 都参与到运算中。设x5 表达式 x>2?T:F 最终返回T. 思路: 1.从后往前遍历字符数组 2.如果遇到的是 非?和 非&…

C++:静态断言内存对齐

静态断言 C中的断言assert (1)直接参考:https://www.cnblogs.com/lvchaoshun/p/7816288.html (2)C的assert是运行时检测发现错误,而不是编译时 (3)C在编译时错误用#error来输出C静态断言 (1)C引入static_assert(表达式, “提示字符串”)来实现编译时的静…