几周前,我在 Google 网站管理员工具中注意到我的一些 URL 正在返回 502。
一个这样的 URL 是http://www.sau.com.au/forums/topic/437438-around-the-bay-wrap-up/
此 URL 为任何桌面皮肤返回 502,但在移动设备上工作正常(不同皮肤)
请注意,它会很快返回 502,这表明它不是执行或某种形式的超时。
除了几个这样的,网站上的所有其他 URL 都很好。
唯一有帮助的日志条目就是这个;
2015/06/29 09:33:39 [错误] 19650#0: *4431763 上游过早关闭 FastCGI 标准输出,同时从上游读取响应标头,客户端:94.228.34.203,服务器:sau.com.au,请求:“GET /论坛/主题/437438-around-the-bay-wrap-up/HTTP/1.1”,上游:“fastcgi://unix:/var/run/php-fpm/php-fpm.sock:”,主机:“ www.sau.com.au”,推荐人:“ http://www.sau.com.au/forums/forum/100-victoria/ ”
我还重新启动了 APC,但没有帮助。它只有 1.5% 的碎片。
我找不到任何达到限制的条目。服务器的规格很高,因此 PHP 有很多内存、请求大小和很长的超时时间。
我尝试了以下我阅读但没有差异的内容。
fastcgi_buffer_size 10240k;
fastcgi_buffers 4 10240k;
我不愿意做任何大的改变,因为这只是在某些页面上。一个线程建议将 PHP 更新到 5.5。
我不知道现在该去哪里寻求进一步的帮助。我的下一步应该是什么?
一些信息;
nginx version: nginx/1.6.2
PHP 5.3.3 (fpm-fcgi) (built: Oct 30 2014 20:14:56)
更新 1
PHP 错误日志没有写入任何内容。虽然启用了错误日志记录;
php_admin_value[error_log] = /var/log/php-fpm/www-error.log
php_admin_flag[log_errors] = on
更新 2
dmesg 似乎没有更新,也没有 kernel.log;
-rw-r--r-- 1 root root 41179 Dec 18 2014 dmesg
解决
我在这个答案中按照@sa289 的建议安装了 XDebug,为此我需要从 PHP 5.3 更新到 PHP 5.5。我希望这会自行解决问题,但事实并非如此。所以,我安装了 XDebug 并将 zend_extension 添加到 php.ini,重新启动 PHP,瞧,502 不见了。我再次注释掉了 zend 扩展并且 502 的返回。XDebug 来救援。没有牢牢把握原因或真正的解决方案,但这对我来说已经足够了。
我会通过使用 Xdebug 查看它可能在哪里崩溃。Xdebug 可用于执行称为跟踪的操作,它会告诉您执行的每一行代码,这样您就可以看到崩溃前运行的最后一行代码,从而为您指明正确的方向。您可以让它仅在设置了某个 cookie 时进行跟踪,这样您就不会为每个请求生成跟踪日志。特别检查以下配置设置:
xdebug.trace_enable_trigger
xdebug.trace_output_dir
xdebug.collect_params
xdebug.trace_output_name
(我喜欢“trace.%p.%t”,因为它将 PID 放在文件名中,这在某些情况下会有所帮助)有关这些配置参数以及其他参数的详细信息,请参阅http://xdebug.org/docs/all_settings 。