zl程序教程

您现在的位置是:首页 >  后端

当前栏目

nginxphp-fpm中启用慢日志配置(用于检测执行较慢的PHP脚本)

PHP配置日志执行 脚本 检测 用于 启用
2023-06-13 09:15:27 时间

很多站长转到nginx+php-fpm后,饱受500,502问题困扰。当nginx收到如上错误码时,可以确定后端php-fpm解析php出了某种问题,比如,执行错误,执行超时。

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

复制代码代码如下:

;ThetimeoutforservingasinglerequestafterwhichaPHPbacktracewillbe
;dumpedtothe"slowlog"file.Avalueof"0s"means"off".
;Availableunits:s(econds)(default),m(inutes),h(ours),ord(ays)
;DefaultValue: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-201314:30:38][poolwww]pid11877
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-201314:15:23]ERROR:[poolwww]"slowlog"mustbespecifiedforusewith"request_slowlog_timeout"


request_slowlog_timeout和slowlog需要同时设置,开启request_slowlog_timeout的同时需要开启slowlog
复制代码代码如下:
[21-Nov-201314:16:27]ERROR:Unabletocreateoropenslowlog(/usr/local/lnmp/php/log/www.log.slow):Nosuchfileordirectory(2)

慢日志路径需要手动创建

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

复制代码代码如下:
cd/usr/local/lnmp/php

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

:wq
保存退出

创建慢日志目录
mkdirlog

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