来源:http://www.nginx.cn/2035.html

很多站长转到nginx+php-fpm后,饱受500,502问题困扰。

当nginx收到如上错误码时,可以确定后端php-fpm解析php出了某种问题,比如,执行错误,执行超时。

php-fpm.conf的配置文件中有一个参数request_slowlog_timeout是这样描述的

; The timeout for serving a single request after which a PHP backtrace will be
; dumped to the 'slowlog' file. A value of '0s' means 'off'.
; Available units: s(econds)(default), m(inutes), h(ours), or d(ays)
; Default Value: 0
;request_slowlog_timeout = 0

当request_slowlog_timeout 设为一个具体秒时request_slowlog_timeout =5,表示如果哪个脚本执行时间大于5秒,会记录这个脚本到慢日志文件中

request_slowlog_timeout =0表示关闭慢日志输出。

慢日志文件位置默认在php的安装目录下的log文件夹中,可以通过修改slowlog = log/$pool.log.slow参数来指定。

php-fpm慢日志的例子,慢日志会记录下进程号,脚本名称,具体哪个文件哪行代码的哪个函数执行时间过长。
[21-Nov-2013 14:30:38] [pool www] pid 11877
script_filename = /usr/local/lnmp/nginx/html/www.quancha.cn/www/fyzb.php
[0xb70fb88c] file_get_contents() /usr/local/lnmp/nginx/html/www.quancha.cn/www/fyzb.php:2

[21-Nov-2013 14:15:23] ERROR: [pool www] 'slowlog' must be specified for use with 'request_slowlog_timeout'

request_slowlog_timeout 和 slowlog需要同时设置,开启request_slowlog_timeout的同时需要开启 slowlog

[21-Nov-2013 14:16:27] ERROR: Unable to create or open slowlog(/usr/local/lnmp/php/log/www.log.slow): No such file or directory (2)

慢日志路径需要手动创建

具体开启php-fpm慢日志步骤:

cd /usr/local/lnmp/php

vi etc/php-fpm.conf
去掉request_slowlog_timeout 、slowlog的前缀分号';',设置request_slowlog_timeout =5;

:wq
保存退出

创建慢日志目录
mkdir log

重启php-fpm
kill -INT `cat var/run/php-fpm.pid
sbin/php-fpm


更多相关文章

  1. 建站学习(PHP+apache+mysql):1.1 日志详解
  2. log4php将不同级别的日志打印到不同的日志文件中
  3. PHP - 在外部服务器上读取文件?
  4. 仅在LARAVEL或AJAX中提交表单时,无需用户身份验证即可将文件上载
  5. PHP ZipArchive 实现压缩解压Zip文件
  6. 纯php文件不加结束标记的好处
  7. 大文件从指定行开始读取
  8. 找不到go-pear。bat文件PHP 5.5 Windows 7。
  9. 将csv文件保存到现有文件,但在新工作表和重命名工作表中

随机推荐

  1. HotSpot 内存分配的主要规则
  2. 我与 Java 的七年之痒
  3. JVM 故障处理工具列表
  4. Object对象你真理解了吗?
  5. MyBatis 如何编写一个自定义插件?运行原理
  6. 请查收,32 道 MyBatis 的高频面试题已答完
  7. 聊聊我是怎么开发Java面试题小程序的
  8. Class 文件的结构
  9. 图解 Class 文件结构
  10. 《深入理解 Java 虚拟机·第三版》读书笔