在 Laravel 5.3 下使用队列时,在 config/queue.php 的配置中,会让开发者指定所用的队列引擎的参数,即“connections”部分。其中有一个参数是 retry_after,据手册上说,它是用来告诉队列在执行一个 job 多久后如果仍未完成,就将该 job 重新放回队列以等待下一次尝试,这一点我能够理解。但是,当在命令行下用 artisan queue:work 开启队列服务的守护进程时,还有一个参数是 --timeout,手册上说它的用意是如果某个执行 job 的队列进程运行时超过了这个时间,就会终止它。而且,手册上还要求这个 --timeout 的时间要稍微少于 retry_after 的时间,否则可能导致某个队列任务被重复执行。
这两个都可以认为是对超时的处理。不过一个是超时重试,一个是超时取消任务。只使用其中一个即可。
手册上说的重试时间稍短于超时时间应该是为了避免超时结束任务导致任务无法被重新放回对接重新执行。
--timeout
应该永远都要比retry_after
短至少几秒钟的时间。这样就能保证任务进程总能在失败重试前就被杀死了。如果你的--timeout
选项大于retry_after
配置选项,你的任务可能被执行两次