> 데이터 베이스 > Redis > Laravel에서 Redis 분산 잠금을 사용하는 방법

Laravel에서 Redis 분산 잠금을 사용하는 방법

WBOY
풀어 주다: 2023-05-28 17:07:06
앞으로
2023명이 탐색했습니다.

Create lock

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿