php - Laravel 作业已尝试太多次或运行时间过长。该作业之前可能已超时
问题描述
我正在使用 Laravel 8 和 Horizon 来异步跟踪付款。作业实现如下所示:
<?php
namespace App\Jobs;
// use ...
class TrackOrderPayment implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
const RETRY_INTERVAL_SECONDS = 60;
public function handle()
{
// Anticipate errors
try {
// implementation ...
} catch (Throwable $exception) {
// Re-queue the job
$this->reQueueJob();
}
}
/**
* Re-queue the job with a delay to try again later
*/
private function reQueueJob(): void
{
$this->delete();
if (this->order->status === Constants::ORDER_STATUS_AWAITING_PAYMENT) {
dispatch(new TrackOrderPayment($this->order))->delay(self::RETRY_INTERVAL_SECONDS);
}
}
}
如果未检测到付款,我将等待最多 15 分钟来检测付款 - 一个单独的 cron 作业将订单更新为不同的状态,因此该作业在 15 分钟(或 15 次尝试,因为重新-queue 设置为 60 秒)
在我config/queue.php
的 redis 队列连接配置中设置如下:
'redis' => [
'driver' => 'redis',
'connection' => 'default',
'queue' => env('REDIS_QUEUE', 'default'),
'retry_after' => 960,
'block_for' => null,
],
我在这里看不到任何其他配置或config/horizon.php
关于最大尝试/超时。
我试图深入了解这一点,为什么某些工作会因此错误而失败:
App\Jobs\TrackOrderPayment 尝试次数过多或运行时间过长。该作业之前可能已超时。
关于这个主题的所有相关问题都说提出retry_after
并且我已经这样做了,它似乎没有帮助。
每次作业运行时,作业的实际“处理”时间小于 0.5 秒,如果未检测到付款,则会延迟 60 秒返回队列。
我在这里想念什么?
解决方案
这是我的一段配置config/horizon.php
,展示了如何实现超时:
'my-supervisor-process' => [
'connection' => 'redis',
'queue' => ['default'],
'balance' => 'simple',
'processes' => 1,
'tries' => 1,
'timeout' => 120,
],
以上内容可能未写在此处的文档中,但确实有效。
我一直在自己挖掘源代码以自己找到这些参数,无论如何我相信上面的配置与以下命令直接相关,您可以看到所有类似的选项(在类中也可见Laravel\Horizon\SupervisorOptions
):
php artisan horizon:supervisor --help
推荐阅读
- python - 如何从 MATLAB 在 Conda 环境中运行 Python 脚本?
- sqlite - SQLite 选择以比较同一行中的两个最后一个订单
- sql-server - 在 SSIS 中将 VARCHAR 转换为 DATE
- azure - Azure API 管理和 App Function 后端:找不到 ID 为“foo”的后端
- android - 如何使用android studio中的按钮创建一个应用程序来重启/重启android手机?
- javascript - 在 django 中一键发送两个表单,修复错误
- expss - 如何删除空行并添加描述性列?
- python - 编写一个文本文件,其中的行有两个单词,用逗号分隔,来自 while 循环
- php - 如果未设置参数,如何给出默认值
- mysql - ELK 数据摄取:elasticsearch 将文本视为布尔值,即使映射显示类型为“文本”