redis 乐观锁

我们经常使用的 redis 锁,是这样的

$redis->set($lock, $value, ['NX', 'EX' => 10]);

这种其实就是一种悲观锁,防止并发,不过这种锁用多了,会造成锁太频繁,降低用户体验。

现在说下乐观锁,简单说,就是乐观的认为每次操作都不会和别人冲突,只在最后更新时,检查更新的数据是否被修改过(类似于 MySQL 中人为添加的版本号 version)。

我们来看下代码

...

// 监控这个 key
$redis->watch($key);

$info = $redis->get($key);
$info = json_decode($info, 1);
// 修改其内容
...

// 开启事务,保存,执行
$rs = $redis->multi()->set($key, json_encode($info))->exec();

if (!$rs) {
    // 没有执行成功,表示此key已经被别人更新了
    $redis->unwatch();
    return 'error';
} else {
    // 执行成功
    return $info;
}
本作品采用《CC 协议》,转载必须注明作者和本文链接
六月的风
Junwind
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 5

json_decode 第二个参数的类型不是 bool 嘛?

file

10个月前 评论
Junwind (楼主) 10个月前

这种方式更简单

$key = 'xxxx';
$res = INCR $key
if ($res !== 1) {
    return
}

EXPIRE $key 6000
// 业务处理
10个月前 评论
Junwind (楼主) 10个月前
Junwind (楼主) 10个月前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!