ホームページ >PHPフレームワーク >Laravel >Laravel で Redis 分散ロックを使用する方法の詳細な説明 (コード例付き)
次のコラム Laravel チュートリアル では、laravel で Redis 分散ロック (アトミックロックのブロック解除) を使用する方法を紹介します。
ロックの作成
use IlluminateSupportFacadesCache; $lock = Cache::lock('foo', 10); if ($lock->get()) { // 处理业务逻辑 sleep(3); $lock->release(); }
無期限のロックを取得し、自動的に解放します
get メソッドはクロージャを受け取ることができます。クロージャーが実行されると、Laravel は自動的にロックを解放します。 [関連する推奨事項: 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(); }
または
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 サイトの他の関連記事を参照してください。