当TTR用完时,QueueWorker会发生什么?

时间:2016-12-21 11:29:19

标签: laravel laravel-5 queue laravel-5.3 beanstalkd

这与使用Queue和QueueWorkers的laravel 5.3,beanstalk,ttr和timeout有关。 TTR:https://github.com/kr/beanstalkd/wiki/faq

如果我理解正确,队列中的作业会在QueueWorker选择时保留状态。当ttr耗尽时,此作业状态将更改回准备状态。但是QueueWorker会发生什么?

假设QueueWorker通过以下命令将超时设置为600:

php artisan queue:work --tries=1 --timeout=600 --sleep=0
默认情况下, ttr设置为60秒。

在作业期间,请求到另一个站点,并且需要120秒直到响应。 60秒后,由于TTR,作业将重新设置为就绪状态。 QueueWorker是否会继续工作直到收到响应,最多600秒?或者,当到达TTR时,QueueWorker是否会停止工作?

1 个答案:

答案 0 :(得分:3)

实际上,QueueWorker将一直运行直到作业完成。当您运行没有守护程序标志的队列工作程序时,它将运行以下代码:

return $this->worker->pop(
    $connection, $queue, $delay,
    $this->option('sleep'), $this->option('tries')
);

参考: https://github.com/laravel/framework/blob/5.2/src/Illuminate/Queue/Console/WorkCommand.php#L123

此代码执行的操作是从队列中弹出作业并将该作业作为命令激活:

public function process($connection, Job $job, $maxTries = 0, $delay = 0)
{
    if ($maxTries > 0 && $job->attempts() > $maxTries) {
        return $this->logFailedJob($connection, $job);
    }

    try {
        $job->fire();

        $this->raiseAfterJobEvent($connection, $job);

        return ['job' => $job, 'failed' => false];
    } catch (Exception $e) {
        if (! $job->isDeleted()) {
            $job->release($delay);
        }

        throw $e;
    } catch (Throwable $e) {
        if (! $job->isDeleted()) {
            $job->release($delay);
        }

        throw $e;
    }
}

参考: https://github.com/laravel/framework/blob/5.2/src/Illuminate/Queue/Worker.php#L213

深入了解更多信息: https://github.com/laravel/framework/tree/5.2/src/Illuminate/Queue