虽然通过nginx accesslog可以记录用户访问某个接口或者网页所消耗的时间,但是不能清晰地追踪到具体哪个位置或者说函数慢,所以通过php-fpm慢日志,slowlog设置可以让我们很好的看见哪些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 =1,表示如果哪个脚本执行时间大于1秒,会记录这个脚本到慢日志文件中

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

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

; 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慢日志步骤:

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

最新文章

  1. Ecplise真机调试(Android)
  2. ruby 编译安装,gem国内源ruby.taobao.org
  3. JSP网站开发基础总结《一》
  4. sublime配置markdown
  5. asp.net 读取RedisSessionStateProvider配置
  6. urllib2.URLError: <urlopen error [Errno 10061] >
  7. mount源码分析 【转】
  8. PHP中使用函数array_merge()合并数组
  9. HDU 3480 Division(斜率优化+二维DP)
  10. 配置Samba服务
  11. unexpected problem
  12. Hdu 4539 【状态DP】.cpp
  13. WPF中静态引用资源与动态引用资源的区别
  14. http://codeforces.com/contest/838/problem/A
  15. 使用MTL库求解最小二乘解
  16. Wechart 饼图
  17. CentOS使用systemctl daemon-reload报错Error getting authority: Error initializing authority: Error calling StartServiceByName for org.freedesktop.PolicyKit1: Timeout was reached (g-io-error-quark, 24)解决办法
  18. 爬虫mm131明星照片
  19. 在谷歌浏览器中安装防广告的插件(abp)
  20. Xpath提取一个标签里的所有文本

热门文章

  1. 网络中,FIFO、LRU、OPT这三种置换算法的缺页次数
  2. ssh 执行命令并实时显示结果
  3. bzoj 1193 贪心+bfs
  4. timeshift 安装使用说明
  5. ElasticStack系列之七 & IK自动热更新原理与实现
  6. 数学建模 TSP(旅行商问题) Lingo求解
  7. 《设计模式》-原则二:里氏代换原则(LSP)
  8. 【译】第五篇 Replication:事务复制-How it works
  9. 更改arch的默认终端
  10. 【算法学习】有旋treap