如何使用redis的setnx实现分布式锁

 更新时间:2024年06月03日 10:27:33   作者:ppo_wu  
Redis Setnx(SET if Not eXists) 命令在指定的 key 不存在时,为 key 设置指定的值,这篇文章主要介绍了使用redis的setnx实现分布式锁,需要的朋友可以参考下

Redis Setnx(SET if Not eXists) 命令在指定的 key 不存在时,为 key 设置指定的值。

语法

redis Setnx 命令基本语法如下:

redis 127.0.0.1:6379> SETNX KEY_NAME VALUE

可用版本

>= 1.0.0

返回值

设置成功,返回 1 。 设置失败,返回 0 。

实例

redis> EXISTS job                # job 不存在
(integer) 0
redis> SETNX job "programmer"    # job 设置成功
(integer) 1
redis> SETNX job "code-farmer"   # 尝试覆盖 job ,失败
(integer) 0
redis> GET job                   # 没有被覆盖
"programmer"

在Redis中,SETNX 是 “Set If Not Exists”(如果不存在,则设置)的缩写。这是一个原子操作,用于设置一个键的值,前提是这个键不存在。如果键已经存在,.则不会执行任何操作。

封装方法trylock,用于获取分布式锁

/**
     * 尝试获  取一个锁。
     *
     * @param name   锁的名称,通常是一个资源的标识。
     * @param expire 锁的过期时间,单位为毫秒。
     * @return 如果获取锁成功,返回一个唯一的token;如果失败,则返回null。
     */
    public String tryLock(String name, long expire) {
        // 为锁名称添加后缀,以避免命名冲突
        name = name + "_lock";
        // 生成一个唯一的token,用于标识持有锁的客户端
        String token = UUID.randomUUID().toString();
        // 获取Redis连接工厂
        RedisConnectionFactory factory = stringRedisTemplate.getConnectionFactory();
        // 获取Redis连接
        RedisConnection conn = factory.getConnection();
        try {
            // 使用SET命令尝试以NX选项(只在键不存在时设置)设置键值对,如果成功,返回true
            // 这里使用了Expiration指定键的过期时间,以确保锁在一段时间后自动释放
            // 参考redis命令:SET key value [EX seconds] [PX milliseconds] [NX|XX]
            Boolean result = conn.set(
                    name.getBytes(), //key
                    token.getBytes(), //value
                    Expiration.from(expire, TimeUnit.MILLISECONDS),
                    RedisStringCommands.SetOption.SET_IF_ABSENT // NX
            );
            // 如果设置成功,返回生成的token
            if (result != null && result)
                return token;
        } finally {
            // 释放Redis连接
            RedisConnectionUtils.releaseConnection(conn, factory, false);
        }
        // 如果未能成功获取锁,返回null
        return null;
    }

接下来,你可以在需要防止并发执行的方法中使用tryLock方法:

public void exampleMethod(String taskName) {
		String lockKey = "myLockKey";
        // 尝试获取锁
        String token = tryLock(lockKey, 10000); // 锁过期时间为10秒
        if (token != null) {
            try {
                // 获取锁成功,执行业务逻辑
                System.out.println("所获取成功");
                // 模拟任务执行
                // ...
            } finally {
                // 释放锁
                stringRedisTemplate.delete(lockKey+ "_lock");
            }
        } else {
            // 获取锁失败,处理失败逻辑
            System.out.println("获取锁失败");
        }
    }

到此这篇关于使用redis的setnx实现分布式锁的文章就介绍到这了,更多相关redis setnx分布式锁内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 巧用Redis实现分布式锁详细介绍

    巧用Redis实现分布式锁详细介绍

    大家好,本篇文章主要讲的是巧用Redis实现分布式锁详细介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • redis执行lua脚本的实现方法

    redis执行lua脚本的实现方法

    redis在2.6推出了脚本功能,允许开发者使用Lua语言编写脚本传到redis中执行。本文就介绍了redis执行lua脚本的实现方法,感兴趣的可以了解一下
    2021-11-11
  • CentOS7.5使用mysql_multi方式安装MySQL5.7.28多实例(详解)

    CentOS7.5使用mysql_multi方式安装MySQL5.7.28多实例(详解)

    这篇文章主要介绍了CentOS7.5使用mysql_multi方式安装MySQL5.7.28多实例,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • Redis 内存淘汰策略深度解析(最新推荐)

    Redis 内存淘汰策略深度解析(最新推荐)

    本文详细探讨了Redis的内存淘汰策略、实现原理、适用场景及最佳实践,介绍了八种内存淘汰策略,包括noeviction、LRU、LFU、TTL、Random等,并分析了它们的应用场景,同时,文章还介绍了Redis内存淘汰的底层实现,包括LRU/LFU的近似算法和淘汰流程,感兴趣的朋友一起看看吧
    2025-03-03
  • Redis高并发场景下秒杀超卖解决方案(秒杀场景)

    Redis高并发场景下秒杀超卖解决方案(秒杀场景)

    早起的12306购票,刚被开发出来使用的时候,12306会经常出现超卖 这种现象,也就是说车票只剩10张了,却被20个人买到了,这种现象就是超卖,今天通过本文给大家介绍Redis高并发场景下秒杀超卖解决方案,感兴趣的朋友一起看看吧
    2022-04-04
  • Redis实现延迟任务的常见方案详解

    Redis实现延迟任务的常见方案详解

    延迟任务(Delayed Task)是指在未来的某个时间点,执行相应的任务,本文为大家整理了Redis实现延迟任务的几个常见方案,希望对大家有所帮助
    2024-04-04
  • 浅谈为什么单线程的redis那么快

    浅谈为什么单线程的redis那么快

    本文主要介绍了为什么单线程的redis那么快,主要介绍了几点原因,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • redis实现动态字符串SDS

    redis实现动态字符串SDS

    简单动态字符串是Redis的基本数据结构之一,用于存储字符串和整型数据,本文主要介绍了redis实现动态字符串SDS,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04
  • Redisson实现分布式锁、锁续约的案例

    Redisson实现分布式锁、锁续约的案例

    这篇文章主要介绍了Redisson如何实现分布式锁、锁续约,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • redis protocol通信协议及使用详解

    redis protocol通信协议及使用详解

    这篇文章主要为大家介绍了redis protocol通信协议及使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07

最新评论