正文
redis的Setnx的简单介绍
小程序:扫一扫查出行
【扫一扫了解最新限行尾号】
复制小程序
【扫一扫了解最新限行尾号】
复制小程序
如何用redis实现分布式锁
使用Redis实现分布式锁redis特性介绍支持丰富的数据类型,如String、List、Map、Set、ZSet等。
如果没有其他线程占用,则就可以通过添加分布式锁来占用这个资源,然后再执行后续的任务,在任务执行完成之后,再释放分布式锁,其他线程就可以继续使用这个资源了。
基于Redis实现分布式锁在网上有很多相关文章,其中主要的实现方式是使用Jedis.setNX方法来实现。
setnx命令怎么读
命令是: setnx expire 添加分布式锁的同时,添加一个锁锁过期的时间。这样,当加锁线程退出之后,至少等一段时间之后,锁是有机会释放掉的。这里有一个小问题是,这两个命令是分开执行的,不是原子操作。
redis是会读从库的。在redis里,所谓setnx,是「SETifNoteXists」的缩写,也就是只有不存在的时候才设置,可以利用它来实现锁的效果,而要实现锁的效果就必须读取从库。
其实目前通常所说的 setnx 命令,并非单指redis的 setnx key value 这条命令,这条命令可能会在后期redis版本中删除。
接下来先看一下对string类型进行基本存储和获取的命令。如果我们存储的string中的内容是数字的话,我们也可以对其进行增或减操作,Redis可以自动的对字符串进行相关的操作。
支持数据持久化,RDB和AOF两种方式支持集群工作模式,分区容错性强单线程,顺序处理命令支持事务支持发布与订阅Redis实现分布式锁使用了SETNX命令:SETNX key value将key的值设为value ,当且仅当key不存在。
setnx 的含义就是 SET if Not Exists,主要有两个参数 setnx(key, value)。该方法是原子的,如果 key 不存在,则设置当前 key 成功,返回 1;如果当前 key 已经存在,则设置当前 key 失败,返回 0。
setnx设置时间,再次设置
可以使用 while 循环重复执行 setnx 命令,并设置一个超时时间退出循环。可以尽量把锁自动过期的时间设的冗余一些。但也不能彻底解决。
setnx 命令不能设置 key 的超时时间,只能通过 expire() 来设置。锁的实现步骤:这个方案如果在第一步 setnx 执行成功后,在 expire() 命令执行成功前,发生了宕机的现象,那么就依然会出现死锁的问题。
使用msetnx时,同时设置一个或多个 key-value 对,当且仅当所有给定 key都不存在时才成立。getset命令从字面意思就可以看出来,他的作用是先get再set。
Redis的Setnx命令实现分布式锁
1、redis分布式锁:实现原理利用redis中的set命令来实现分布式锁。从Redis 12版本开始,set可以使用下列参数:SET KEY VALUE [EX seconds] [PX milliseconds] [NX|XX] EX second :设置键的过期时间为second秒。
2、SETNX不同:SETNX(SETifNoteXists),该命令在key不存在时设置key的值,如果key存在,不做任何操作。Redishash数据结构可以存储多个键值对,所以我们可以使用Redishash实现分布式锁。
3、命令是: setnx expire 添加分布式锁的同时,添加一个锁锁过期的时间。这样,当加锁线程退出之后,至少等一段时间之后,锁是有机会释放掉的。这里有一个小问题是,这两个命令是分开执行的,不是原子操作。
4、那这时候,我们就需要一个跨平台、跨语言的加锁方式。redis就是其中最方便的一种。使用redis实现并发锁,主要是靠两个redis的命令:setnx和getset。
5、EX 10010 指定过期时间 NX 只在键不存在时,才对键进行设置操作。效果等同于 SETNX 命令。只不过早期版本redis不支持set的扩展参数,这就需要用到 lua 脚本了 。
6、Redis有一系列的命令,特点是以NX结尾,NX是Not eXists的缩写,如SETNX命令就应该理解为:SET if Not eXists。这系列的命令非常有用,这里讲使用SETNX来实现分布式锁。用SETNX实现分布式锁 利用SETNX非常简单地实现分布式锁。
关于redis的Setnx和的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。