nginx php-fpm中启用慢日志配置(用于检测执行较慢的PHP脚本)
很多站长转到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
相关推荐
zhaowj00 2020-07-30
igogo00 2020-03-04
Skyline 2020-03-01
zhaowj00 2020-02-19
pupur 2015-08-19
寻常白昼 2011-05-01
缘起宇轩阁 2019-08-22
aaLiweipeng 2019-04-29
梦想启航 2016-08-22
luckymaoyy 2015-08-19
梦想启航 2015-05-25
WFMoonlight 2020-08-17
有梦就能实现 2020-06-26
Skyline 2020-06-25
dajiangqingzhou 2020-05-07
olyqcool 2020-05-10
jkzyx 2020-04-25