php7 slowlog,php-fpm中启用慢日志配置

转载自

php-fpm慢日志slowlog设置可以让开发者很好的查找哪些php进程速度过慢而导致的网站问题,让开发者方便的找到问题的所在。该方法同样适用于排查nginx的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/nginx/html/www.quancha.cn/www/fyzb.php

[0xb70fb88c] file_get_contents() /usr/local/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/php/log/www.log.slow):

No such file or directory (2)慢日志路径需要手动创建,具体开启php-fpm慢日志步骤:cd /usr/local/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. cd /usr/local/php5/

2. sed -i.$(date +%F) '/;slowlog/s/;slowlog/slowlog/g' etc/php-fpm.conf

3. sed -i '/;request_slowlog_timeout = 0/s/;request_slowlog_timeout = 0/request_slowlog_timeout = 5/g' etc/php-fpm.conf

4. mkdir log

5. 测试配置文件

# /usr/local/php5/sbin/php-fpm -t

[29-Sep-2015 18:58:35] NOTICE: configuration file /usr/local/php5/etc/php-fpm.conf tes   t is successful

6. 平滑重启

#/etc/init.d/php-fpm reload

Reload service php-fpm  done

7. 查看日志

[root@movie php5]# ll log/

total 0

-rw------- 1 root root 0 Sep 29 18:35 www.log.slow

其中慢查询日志的文件名是由slowlog = log/$pool.log.slow指定的。

默认文件名为$pool.log.slow,而变量pool可在php-fpm配置文件中指定。

119 ; Pool Definitions ;

120 ;;;;;;;;;;;;;;;;;;;;

121

122 ; Multiple pools of child processes may be started with different listening

123 ; ports and different management options.  The name of the pool will be

124 ; used in logs and stats. There is no limitation on the number of pools which

125 ; FPM can handle. Your system will tell you anyway :)

126

127 ; Start a new pool named 'www'.

128 ; the variable $pool can we used in any directive and will be replaced by the

129 ; pool name ('www' here)

130 [www]

将130行的的[www]更改为[test],平滑重启后,即可看到poolname变为test,产生新的日志文件test.log.slow

bbd9bb23947ce16a98090fbfe319ba40.png

[root@movie php5]# ll log/

total 0

-rw------- 1 root root 0 Sep 29 19:24 test.log.slow

-rw------- 1 root root 0 Sep 29 18:35 www.log.slow

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值