Laravel Redis分布式锁的使用


 Laravel Redis分布式锁的使用 

创建锁

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

获取无限期锁并自动释放

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

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

在指定时间内获取锁

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秒时间内成功获取锁..."; });

无视拥有者强制释放锁

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();

原文地址:https://www.cnblogs.com/danhuang/p/13266960.html


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM