【发布时间】:2020-11-04 10:21:08
【问题描述】:
问题
我正在分派一个作业来执行一个需要准备好正确执行资源的操作,因此如果它失败了,它需要在一段时间后重试。 但真正发生的是,如果它失败了,它就不会再次执行。 我正在使用 Supervisor 来管理队列和数据库驱动程序,并且我在默认的 queue.php 配置文件中没有进行任何更改。
使用 Laravel 5.8。
我的尝试
我已经尝试在作业类中手动设置尝试次数,例如
public $tries = 5;
重试延迟也是一样的
public $retryAfter = 60;
我的代码
我正在根据使用 make:job 制作的默认作业模板来实现此作业,我的构造函数和句柄方法如下所示:
public function __construct($event, $data)
{
$this->event = $event;
$this->data = $data;
}
public function handle()
{
Log::info('Job started | ' . $this->event . ' | Attempt: ' . $this->attempts());
// Executes some logic and throws an Exception if it fails
Log::info('Job succeeded | ' . $this->event);
}
最后它没有达到“作业成功”日志,也没有记录除 1 之外的任何其他尝试。
是否有一些我遗漏的概念或者这段代码有什么错误?
【问题讨论】: