虽然经过nginx accesslog能够记录用户访问某个接口或者网页所消耗的时间,可是不能清晰地追踪到具体哪一个位置或者说函数慢,因此经过php-fpm慢日志,slowlog设置能够让咱们很好的看见哪些php进程速度太慢而致使的网站问题php
php-fpm.conf的配置文件中有一个参数request_slowlog_timeout是这样描述的nginx
; 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 =1,表示若是哪一个脚本执行时间大于1秒,会记录这个脚本到慢日志文件中web
request_slowlog_timeout =0表示关闭慢日志输出。app
慢日志文件位置默认在php的安装目录下的log文件夹中,能够经过修改slowlog = log/$pool.log.slow参数来指定。webapp
; The log file for slow requests ; Default Value: not set ; Note: slowlog is mandatory if request_slowlog_timeout is set ; slowlog = log/$pool.log.slow
php-fpm慢日志的例子,慢日志会记录下进程号,脚本名称,具体哪一个文件哪行代码的哪一个函数执行时间过长。函数
[27-May-2016 13:20:37] NOTICE: child 16683 stopped for tracing [27-May-2016 13:20:37] NOTICE: about to trace 16683 [27-May-2016 13:20:37] NOTICE: finished trace of 16683 [27-May-2016 13:20:37] WARNING: [pool www] child 16720, script '/Data/webapps/test/public/index.php' (request: "POST /index.php/test/test/") executing too slow (1.204894 sec), logging
request_slowlog_timeout 和 slowlog须要同时设置,开启request_slowlog_timeout的同时须要开启 slowlog,慢日志路径须要手动建立php-fpm
具体开启php-fpm慢日志步骤:网站
cd /apps/php vi /apps/php/etc/php-fpm.conf 去掉request_slowlog_timeout 、slowlog的前缀分号';',设置request_slowlog_timeout =1; :wq 保存退出 建立慢日志目录 mkdir -p /apps/php/etc/log 重启php-fpm killall php-fpm /apps/php/sbin/php-fpm