任务执行时间
在配置文件config/queue.php中,每个连接都定义了retry_after项。该配置项的目的是定义任务在执行以后多少秒后释放回队列。如果retry_after设定的值为90, 任务在运行90秒后还未完成,那么将被释放回队列而不是删除掉。毫无疑问,你需要把retry_after的值设定为任务执行时间的最大可能值。
'redis'=> [
'driver'=>'redis',
'connection'=>'default',
'queue'=>'default',
'retry_after'=>90,
],
队列进程超时
队列进程queue:work可以设定超时--timeout项。该--timeout控制队列进程执行每个任务的最长时间,如果超时,该进程将被关闭。各种错误都可能导致某个任务处于“冻结”状态,比如 HTTP 无响应等。队列进程超时就是为了将这些“冻结”的进程关闭:
php artisan queue:work --timeout=85
也可在任务类指定
public $timeout=85;
注意
配置项retry_after 和 Aritisan 参数项--timeout不同,但目的都是为了确保任务的安全,并且只被成功的执行一次。参数项--timeout的值应该是中小于配置项retry_after的值,这是为了确保队列进程总在任务重试以前关闭。如果--timeout比retry_after大,则你的任务可能被执行两次。