zoukankan      html  css  js  c++  java
  • 【PHP】善用php-fpm的慢执行日志slow log,分析php性能问题

    (转)善用php-fpm的慢执行日志slow log,分析php性能问题

     众所周知,mysql有slow query log,根据慢查询日志,我们可以知道那些sql语句有性能问题。作为mysql的好搭档,php也有这样的功能。如果你使用php-fpm来管理php的话,你可以通过如下选项开启。

    PHP 5.3.3 之前设置如下:
    <value name=”request_slowlog_timeout”>5s</value>
    <value name=”slowlog”>logs/php-fpm-slowlog.log</value>

    PHP 5.3.3 之后设置以下如下:
    request_slowlog_timeout = 5s
    slowlog = /usr/local/php/log/php-fpm-slowlog.log

    说明:
    request_slowlog_timeout 是脚本超过多长时间 就可以记录到日志文件
    slowlog 是日志文件的路径

    开启后,如果有脚本执行超过指定的时间,就会在指定的日志文件中写入类似如下的信息:

    [19-Dec-2013 16:54:49] [pool www] pid 18575
    script_filename = /home/web/htdocs/sandbox_canglong/test/tt.php
    [0x0000000003a00dc8] curl_exec() /home/web/htdocs/sandbox_canglong/test/tt.php:2
    [0x0000000003a00cd0] exfilter_curl_get() /home/web/htdocs/sandbox_canglong/test/tt.php:6

    日志说明:
    script_filename 是入口文件
    curl_exec() : 说明是执行这个方法的时候超过执行时间的。
    exfilter_curl_get() :说明调用curl_exec()的方法是exfilter_curl_get() 。
    每行冒号后面的数字是行号。

    开启后,在错误日志文件中也有相关记录。如下:

    [19-Dec-2013 15:55:37] WARNING: [pool www] child 18575, script ‘/home/web/htdocs/sandbox_canglong/test/tt.php’ (request: “GET /test/tt.php”) executing too slow (1.006222 sec), logging
    [19-Dec-2013 15:55:37] NOTICE: child 18575 stopped for tracing
    [19-Dec-2013 15:55:37] NOTICE: about to trace 18575
    [19-Dec-2013 15:55:37] NOTICE: finished trace of 18575

  • 相关阅读:
    PHP发送邮件
    SQL删除字段及判断字段是否存在的方法
    密码MySQL的root的密码
    java socket 最简单的例子(server 多线程)
    php编写最简单的webservice
    SQL Server 存储过程与触发器
    手动创建最简单的JSP 文件
    Oracle 卸载步骤
    编写 WebService 程序
    eclipse 常用快捷键
  • 原文地址:https://www.cnblogs.com/zhuzhubaoya/p/9207971.html
Copyright © 2011-2022 走看看