Laravel 큐를 사용할 때 작업 실행 실패가 발생할 수 있습니다. 이때 Laravel은 실패 대기열을 사용하는 좋은 솔루션을 제공합니다.
대기열 작업을 실행할 때 실패한 작업을 실패한 작업을 처리하도록 특별히 설계된 대기열에 넣은 다음 정기적으로 이 대기열을 확인하고 그 안에 있는 실패한 작업을 다시 실행할 수 있습니다. 이런 방식으로 우리는 사소한 문제로 인해 대기열 작업이 종료되는 것을 방지하고 계속해서 서비스를 제공할 수 있습니다.
Laravel의 실패 대기열은 필요에 따라 구성할 수 있는 다양한 구성과 확장 가능한 인터페이스를 제공합니다.
먼저 실패한 작업이 구성 파일 config/queue.php
에 입력해야 하는 대기열을 설정해야 합니다. 이 구성 항목의 키는 실패
이고 해당 값은 드라이버
및 큐
라는 두 가지 구성 항목을 포함하는 배열입니다. driver
구성 항목은 우리가 사용하려는 오류 드라이버를 나타냅니다. Laravel은 기본적으로 database
및 redis
라는 두 가지 오류 드라이버를 제공합니다. 그리고 queue
는 실패한 작업이 들어갈 대기열을 나타냅니다. config/queue.php
中设置失败的任务应该进入的队列。该配置项的键为 failed
,其值为一个数组,其中包含 driver
和 queue
两个配置项。driver
配置项表示我们希望使用哪个失败驱动,Laravel 默认提供了 database
和 redis
两个失败驱动。而 queue
则表示失败任务将进入哪个队列。
'failed' => [ 'driver' => 'database', 'queue' => 'failed', ],
如果我们希望使用其他的失败驱动,我们可以通过注册自定义失败驱动并在 driver
配置项中引用它来实现。
注册自定义驱动的代码如下所示:
Queue::failing(function ($connection, $job, $data) { // 自定义处理逻辑 });
接下来,我们需要定义处理失败任务的具体逻辑。我们可以直接将失败任务再次推入队列中,这样在下一次队列处理时该任务就会再次被执行。或者,我们也可以将失败任务的一些信息存储下来以备后续检查以及处理。
对于将失败任务推入队列的处理方式,我们可以使用以下代码:
Queue::failing(function ($connection, $job, $data) { $queue = $job->getQueue(); $payload = $job->payload(); Queue::pushRaw($payload, $queue); });
这段代码将失败任务重新推到了原始队列中,等待下一次被执行。
而对于将失败任务信息存储的处理方式,我们可以使用以下代码:
Queue::failing(function ($connection, $job, $data) { // 将失败任务信息存储到数据库中 DB::table('failed_jobs')->insert([ 'connection' => $connection, 'queue' => $job->getQueue(), 'payload' => $job->getRawBody(), 'exception' => $data['exception'], 'failed_at' => now(), ]); });
这段代码将失败任务的信息存储到数据库表 failed_jobs
中,以便我们稍后进行检查以及处理。
除了以上两种处理方式,Laravel 还提供了更多的处理方式供我们选择。我们可以查看 Laravel 的文档以及源代码以了解更多详情。
最后,我们需要定期检查失败队列并重试其中的任务。Laravel 默认提供了 queue:retry
命令来进行任务重试,该命令接受一个可选参数 --queue
,表示我们要重试的任务队列。如果不指定该参数,则默认重试所有队列。
php artisan queue:retry 5 --queue=my-queue
该命令将会从失败队列中的 my-queue
队列中重新执行前 5 个失败任务。
除此之外,我们还可以使用操作系统的定时任务工具(如 crontab)来周期性地执行 queue:retry
rrreee
드라이버
구성 항목에서 이를 참조하면 됩니다. 커스텀 드라이버를 등록하는 코드는 다음과 같습니다. rrreee
다음으로 실패한 작업을 처리하기 위한 특정 로직을 정의해야 합니다. 실패한 작업을 다시 큐에 직접 넣을 수 있으므로 다음 큐 처리 중에 해당 작업이 다시 실행됩니다. 또는 후속 검사 및 처리를 위해 실패한 작업에 대한 일부 정보를 저장할 수도 있습니다. 🎜🎜실패한 작업을 대기열에 푸시하는 처리 방법으로 다음 코드를 사용할 수 있습니다. 🎜rrreee🎜이 코드는 실패한 작업을 원래 대기열로 다시 푸시하고 다음에 실행될 때까지 기다립니다. 🎜🎜실패한 작업 정보를 저장하는 방법은 다음 코드를 사용할 수 있습니다. 🎜rrreee🎜이 코드는 실패한 작업 정보를 나중에 확인하고 처리할 수 있도록 데이터베이스 테이블failed_jobs
에 저장합니다. 🎜🎜위의 두 가지 처리 방법 외에도 Laravel은 선택할 수 있는 더 많은 처리 방법을 제공합니다. 자세한 내용은 Laravel의 문서와 소스 코드를 확인하세요. 🎜🎜마지막으로 실패 대기열을 주기적으로 확인하고 그 안에 있는 작업을 다시 시도해야 합니다. Laravel은 작업을 재시도하기 위해 기본적으로 queue:retry
명령을 제공합니다. 이 명령은 재시도하려는 작업 큐를 나타내는 선택적 매개변수 --queue
를 허용합니다. 이 매개변수를 지정하지 않으면 기본적으로 모든 대기열이 재시도됩니다. 🎜rrreee🎜이 명령은 실패 대기열의 my-queue
대기열에서 처음 5개의 실패한 작업을 다시 실행합니다. 🎜🎜또한 운영 체제의 예약 작업 도구(예: crontab)를 사용하여 정기적으로 queue:retry
명령을 실행하여 실패한 작업을 정기적으로 처리할 수도 있습니다. 🎜🎜간단히 말하면, Laravel의 실패 대기열은 대기열 작업의 실패를 처리하는 데 매우 유용한 솔루션을 제공합니다. 우리는 필요에 따라 이를 구성하고 다양한 방법으로 실패한 작업을 처리할 수 있습니다. 동시에 실패 대기열을 정기적으로 확인하고 그 안에 있는 작업을 재시도하여 대기열 작업이 정상적으로 실행될 수 있는지 확인해야 합니다. 🎜🎜이 기사가 모든 사람에게 도움이 되기를 바랍니다. 🎜위 내용은 Laravel 대기열이 실패하면 어떻게 되나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!