• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

php-fpm 慢日志查询

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

      虽然可以通过 nginx 的 accesslog 日志查询到用户访问接口或网页消耗的时间,但是不能清晰的追踪到哪个文件或函数慢,

可以通过 php-fpm 慢日志查询检测 php 脚本运行状态,哪些 php 进程比较慢,有哪些错误日志

      1 先查找到配置文件存放的位置

find / -name php-fpm.conf

      打开配置文件看慢日志查询是否开启,或者开启的慢日志存放路径

      2 如果没有开启慢日志查询,先开启

         默认情况下 request_slowlog_timeout 的值为 0,表示关闭慢日志输出,所以开启慢日志查询需要将 request_slowlog_timeout

设置成大于 0 的值,表示 php 脚本执行时间超过 request_slowlog_timeout 设置的时间将会被记录到 slowlog 中,然后查看慢日志对

脚本进行对应的处理

        request_slowlog_timeout 和 slowlog 需要同时开启,slowlog 表示慢日志存储的位置,我们可以自定义也可以直接使用默认的位置

默认的位置一般在 /data/php/log/php-fpm.log ,同时需要将 request_slowlog_timeout、slowlog 前面的分号去掉才算是开启,然后重启

php-fpm

       3 观察慢日志信息

         开启后,如果有脚本执行时间超过设置时间,会被记录到指定的日志文件中,格式如下(摘抄来自网上):

[19-Dec-2016 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() 方法,每行冒号之后

都会有数字表示行号

       开启后,对错误日志也有相关记录,如下


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
php处理高精度计算函数发布时间:2022-07-10
下一篇:
Log4PHP日志库使用发布时间:2022-07-10
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap