ホームページ >データベース >Redis >LaravelでRedis分散ロックを使用する方法

LaravelでRedis分散ロックを使用する方法

WBOY
WBOY転載
2023-05-28 17:07:062019ブラウズ

ロックの作成

use IlluminateSupportFacadesCache;

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

無期限のロックを取得し、自動的に解放します

get メソッドはクロージャを受け取ることができます。クロージャーが実行されると、Laravel は自動的にロックを解放します。

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

指定された時間内にロックを取得します

use IlluminateContractsCacheLockTimeoutException;

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

Or

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

所有者を無視してロックを強制的に解放します

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

クロスプロセス管理ロック

// 控制器中...
$podcast = Podcast::find($id);
$lock = Cache::lock('foo', 120);
if ($result = $lock->get()) {
    ProcessPodcast::dispatch($podcast, $lock->owner());
}

// 队列任务中...
// 使用锁名称和拥有者重新获取锁实例后再释放
Cache::restoreLock('foo', $this->owner)->release();

以上がLaravelでRedis分散ロックを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。