社区微信群开通啦,扫一扫抢先加入社区官方微信群
社区微信群
Redis分布式锁实现:适用于单机模式,集群模式不可行,失效时间不好控制,一般为业务时间的2-3倍左右。
SET key value [EX seconds] [PX milliseconds] [NX|XX]
将字符串值 value
关联到 key
。
如果 key
已经持有其他值, SET 就覆写旧值,无视类型。
对于某个原本带有生存时间(TTL)的键来说, 当 SET 命令成功在这个键上执行时, 这个键原有的 TTL 将被清除。
可选参数
从 Redis 2.6.12 版本开始, SET 命令的行为可以通过一系列参数来修改:
EX second
:设置键的过期时间为 second
秒。 SET key value EX second
效果等同于 SETEX key second value
。PX millisecond
:设置键的过期时间为 millisecond
毫秒。 SET key value PX millisecond
效果等同于 PSETEX key millisecond value
。NX
:只在键不存在时,才对键进行设置操作。 SET key value NX
效果等同于 SETNX key value
。XX
:只在键已经存在时,才对键进行设置操作。因为 SET 命令可以通过参数来实现和 SETNX 、 SETEX 和 PSETEX 三个命令的效果,所以将来的 Redis 版本可能会废弃并最终移除SETNX 、 SETEX 和 PSETEX 这三个命令。
可用版本:
>= 1.0.0
时间复杂度:
O(1)
返回值:
在 Redis 2.6.12 版本以前, SET 命令总是返回 OK
。
从 Redis 2.6.12 版本开始, SET 在设置操作成功完成时,才返回 OK
。
如果设置了 NX
或者 XX
,但因为条件没达到而造成设置操作未执行,那么命令返回空批量回复(NULL Bulk Reply)。
-----------------------------------------------------------------------------------------------------------------------------------------------------------
Zookeeper实现分布式锁:
一:创建临时节点:
path改为protected
二:创建临时有序节点:
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!