Redis分布式锁实现,Zookeeper实现分布式锁

Redis分布式锁实现:适用于单机模式,集群模式不可行,失效时间不好控制,一般为业务时间的2-3倍左右。

Redis分布式锁实现,Zookeeper实现分布式锁_第1张图片

Redis分布式锁实现,Zookeeper实现分布式锁_第2张图片

Redis分布式锁实现,Zookeeper实现分布式锁_第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实现分布式锁:

Redis分布式锁实现,Zookeeper实现分布式锁_第4张图片

一:创建临时节点:

Redis分布式锁实现,Zookeeper实现分布式锁_第5张图片path改为protected

Redis分布式锁实现,Zookeeper实现分布式锁_第6张图片

 

Redis分布式锁实现,Zookeeper实现分布式锁_第7张图片

Redis分布式锁实现,Zookeeper实现分布式锁_第8张图片

Redis分布式锁实现,Zookeeper实现分布式锁_第9张图片

Redis分布式锁实现,Zookeeper实现分布式锁_第10张图片

 

二:创建临时有序节点:

Redis分布式锁实现,Zookeeper实现分布式锁_第11张图片

Redis分布式锁实现,Zookeeper实现分布式锁_第12张图片

Redis分布式锁实现,Zookeeper实现分布式锁_第13张图片
Redis分布式锁实现,Zookeeper实现分布式锁_第14张图片

Redis分布式锁实现,Zookeeper实现分布式锁_第15张图片

 

你可能感兴趣的:(大数据)