$timeout = 3;
$id = 1;
$key = 'my:lock';
$value = 'lock_'.$id;
$isLock = Redis::get($key);//ex 秒
if ($isLock) {
for ($i = 0; $i < 3; $i++) { //重试3次
if ($lock) {
sleep($i + 1);
} else {
//没锁了, 就是可以获取数据了
$value = Redis::get($key);
return $value;
}
}
}else{
//执行其他操作
$isLock = Redis::set($key, $value, 'ex', $timeout, 'nx');//ex 秒
.....
Redis::del($key);
}

本文介绍了一种使用Redis实现分布式锁的策略,通过设置键值和过期时间来防止并发冲突,确保数据的一致性和完整性。文章详细展示了如何利用Redis的set命令实现加锁,并在完成操作后释放锁。
703

被折叠的 条评论
为什么被折叠?



