redis分布式锁简说

setnx

SETNX+EXPIRE

$redis->multi();
$redis->setNX($key, $value);
$redis->expire($key, $ttl);
$redis->exec();

如果可能出现死锁:那么可以使用value值为时间戳+过期时间模式,在下一个执行获取锁是,如果拿不到锁,那么判断时间是否有真实过期,若过期,删除锁,再重新获得


SET


SET key value [EX seconds] [PX milliseconds] [NX|XX]

将字符串值 value 关联到 key 。

***如果 key 已经持有其他值, SET 就覆写旧值,无视类型。

可选参数

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 这三个命令。

事例

SET k1 v1 NX PX 30000    key不存在时生效,设置过期时间为30000毫秒
SET k1 v1 NX EX 30    key不存在时生效,设置过期时间为30秒
SET k1 v1 XX EX 300    key * 存在 *时生效,设置过期时间为300秒
SET k1 v1    覆写旧值,无视类型,如有TTL 将被清除。任何key都将回归普通key,v形式
返回值:
在 Redis 2.6.12 版本以前, SET 命令总是返回 OK 。

从 Redis 2.6.12 版本开始, SET 在设置操作成功完成时,才返回 OK 。
如果设置了 NX 或者 XX ,但因为条件没达到而造成设置操作未执行,那么命令返回空批量回复(NULL Bulk Reply)。

使用SET代替SETNX ,相当于SETNX+EXPIRE实现了原子性,不必担心SETNX成功,EXPIRE失败的问题!

猜你喜欢

转载自blog.csdn.net/fclwd/article/details/88344766