php进程超时接口返回504错误分析
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php进程超时接口返回504错误分析相关的知识,希望对你有一定的参考价值。
参考技术A在一次接口测试中,发现返回的http 504 time out 的错误,然后查看了php-fpm的错误日志,发现了如下错误
从表现上看,是php进程超时导致的进程被kill了,那么这个超时时间以及kill的机制是跟哪些参数有关呢,这里系统这里一下。
nginx服务一般因为php的错误或者超时会有两种错误码502 bad Gateway 或者 504 Gateway Time-out
一种情况是php产生了语法错误,比如循环调用、变量作用域错误、方法不存在等,如果开启错误日志输出的话,这种错误在php-fpm的错误日志中是可以看到调用栈信息的。
另外一种情况可能就是超时引起的php-fpm主动kill的情况,在php.ini和php.fpm中有两个配置项,用来管理php脚本的最大执行时间
当php脚本的执行时间超过这个时间时,PHP-FPM不只会终止脚本的执行,还会终止执行脚本的Worker进程。所以Nginx会发现与自己通信的连接断掉了,就会返回给客户端502错误。
以顶部的错误为例,当报502错误是,nginx的errorlog中有如下日志,:
所以只需将这两项的值调大一些就可以让PHP脚本不会因为执行时间长而被终止了。request_terminate_timeout可以覆盖max_execution_time,
所以如果不想改全局的php.ini,那只改PHP-FPM的配置就可以了。
此外要注意的是Nginx的upstream模块中的max_fail和fail_timeout两项。这两个配置表示在fail_timeout事件内,如果fail的测试达到max_fail,那么在接下来的fail_timeout时间内,Nginx都会认为上游服务器挂掉了,都会返回502错误。
所以可以将max_fail调大一些,将fail_timeout调小一些。
PHP-FPM设置的脚本最大执行时间已经够长了,但执行耗时PHP脚本时,发现Nginx报错从502变为504了。这是为什么呢?
因为我们修改的只是PHP的配置,Nginx中也有关于与上游服务器通信超时时间的配置
以Nginx超时时间为90秒,PHP-FPM超时时间为300秒为例,报504 Gateway Timeout错误时的Nginx错误访问日志如下:
调高这三项的值(主要是read和send两项,默认不配置的话Nginx会将超时时间设为60秒)之后,504错误也解决了。
而且这三项配置可以配置在http、server级别,也可以配置在location级别。担心影响其他应用的话,就配置在自己应用的location中吧。
要注意的是factcgi_connect/read/send_timeout是对FastCGI生效的,而proxy_connect/read/send_timeout是对proxy_pass生效的。
参考链接: http://www.cnblogs.com/fei33423/p/8184098.html 感谢分享!
Laravel队列进程超时错误
我在Laravel上使用php artisan queue:listen
来运行排队的工作。其中一个工作相当复杂,需要很长时间,因此我收到以下错误:
[SymfonyComponentProcessExceptionProcessTimedOutException]
The process ""/usr/local/Cellar/php55/5.5.14/bin/php" artisan queue:work
--queue="QUEUE_URL" --delay=0 --memory=128 --sleep=3 --tries=0"
exceeded the timeout of 60 seconds.
我知道我可以运行具有任意高超时值的queue:listen
,但这并不理想,因为我希望它在某些进程实际上没有响应的情况下超时。我尝试在作业调用的函数中定期调用set_time_limit(60)
,但这并没有解决我的问题。
我发现在线提到SymfonyComponentProcessProcess->setTimeout(null)
的线程,但我不知道如何访问该进程对象,或者如果这甚至可以解决问题。
任何帮助将非常感激。
添加--timeout=0
为我的设置工作。
更新:整个命令因此将是php artisan queue:listen --timeout=0
。
希望这可以帮助。
这是Laravel v5.3中已知的bug:
您应升级到v5.5以解决此问题。
另一种方法是黑客攻击源代码,如here所述
以上是关于php进程超时接口返回504错误分析的主要内容,如果未能解决你的问题,请参考以下文章