Laravel Redis分布式锁的使用

Laravel2021-02-24 08:12:37430条
laravel的缓存类的store的redis实现,位于命名空间Illuminate\Cache\RedisStore,其中实现了LockProvider,可获取锁实例,锁实例为Illuminate\Cache\RedisLock类的实例,RedisLock类是Illuminate\Cache\Lock抽象类的实现。

1. 创建锁

use Illuminate\Support\Facades\Cache;

$lock = Cache::lock('foo', 10);
if ($lock->get()) {
    // 处理业务逻辑
    sleep(3);
    $lock->release();
}

2. 获取无限期锁并自动释放

get方法可以接收一个闭包。在闭包执行之后,Laravel 将会自动释放锁。

Cache::lock('foo')->get(function () {
    // 获取无限期锁并自动释放...
});

3. 在指定时间内获取锁

use Illuminate\Contracts\Cache\LockTimeoutException;

$lock = Cache::lock('foo', 10);
try {
    $lock->block(5);
    echo "5秒时间内成功获取锁...";
} catch (LockTimeoutException $e) {
    echo "5秒时间内获取锁失败...";
} finally {
    optional($lock)->release();
}

另一种写法:

Cache::lock('foo', 10)->block(5, function () {
    echo "5秒时间内成功获取锁...";
});

4. 无视拥有者强制释放锁

Cache::lock('foo')->forceRelease();

5. 跨进程管理锁

// 控制器中...
$podcast = Podcast::find($id);
$lock = Cache::lock('foo', 120);
if ($result = $lock->get()) {
    ProcessPodcast::dispatch($podcast, $lock->owner());
}
// 队列任务中...
// 使用锁名称和拥有者重新获取锁实例后再释放
Cache::restoreLock('foo', $this->owner)->release();
评论啦~
暂无评论,快来抢沙发吧!