前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >12.22 php-fpm慢执行日志

12.22 php-fpm慢执行日志

作者头像
运维小白
发布2018-02-06 15:58:30
1.6K0
发布2018-02-06 15:58:30
举报
文章被收录于专栏:运维小白

php-fpm慢执行日志目录概要

  • vim /usr/local/php-fpm/etc/php-fpm.d/www.conf//加入如下内容
代码语言:javascript
复制
request_slowlog_timeout = 1
slowlog = /usr/local/php-fpm/var/log/www-slow.log
  • 配置nginx的虚拟主机test.com.conf,把unix:/tmp/php-fcgi.sock改为unix:/tmp/www.sock
  • 重新加载nginx服务
  • vim /data/wwwroot/test.com/sleep.php//写入如下内容
代码语言:javascript
复制
<?php 
echo “test slow log”;
sleep(2);echo “done”;
?>
  • curl -x127.0.0.1:80 test.com/sleep.php
  • cat /usr/local/php-fpm/var/log/www-slow.log

php-fpm慢执行日志

  • 在做php网站的时候,建议使用lnmp,因为我们可以分析php的慢执行
  • 查询方法:
    • 1.系统负载,可以通过各种工具查,查出是哪个进程导致
    • 2.PHP网站访问慢,通过查看慢日志
  1. 配置www.conf 在配置文件中加入
代码语言:javascript
复制
request_slowlog_timeout = 1    //超过一秒钟就要记录日志
slowlog = /usr/local/php-fpm/var/log/www-slow.log    //日志放到该路径下

最终如下

代码语言:javascript
复制
[root@hanfeng php-fpm.d]# vim www.conf

[www]
listen = /tmp/php-fcgi.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024
request_slowlog_timeout = 1
slowlog = /usr/local/php-fpm/var/log/www-slow.log
保存退出
  1. 查看语法错误,并重新加载
代码语言:javascript
复制
[root@hanfeng php-fpm.d]# /usr/local/php-fpm/sbin/php-fpm -t
[10-Jan-2018 00:04:26] NOTICE: configuration file /usr/local/php-fpm/etc/php-fpm.conf test is successful

[root@hanfeng php-fpm.d]# /etc/init.d/php-fpm reload
Reload service php-fpm  done
[root@hanfeng php-fpm.d]# 
  1. 查看/usr/local/php-fpm/var/log/www-slow.log日志是否生成
代码语言:javascript
复制
[root@hanfeng php-fpm.d]# ls /usr/local/php-fpm/var/log/
php-fpm.log  www-slow.log
[root@hanfeng php-fpm.d]# 
  1. 查看日志会看到没有内容,因为没有超过一秒php执行的过程
代码语言:javascript
复制
[root@hanfeng php-fpm.d]# cat /usr/local/php-fpm/var/log/www-slow.log 
[root@hanfeng php-fpm.d]# 
  1. 模拟一个慢执行的php,写一个脚本,由于php-fcgi它是被在test这个站点用着,所以需要在这个/data/wwwroot/test.com目录下做一些操作
代码语言:javascript
复制
[root@hanfeng php-fpm.d]# vim /data/wwwroot/test.com/sleep.php
加入php休眠两秒钟,故意让它执行慢
<?php
echo “test slow log”;
sleep(2);echo “done”;
?>
保存退出
  • php可以不换行,写成一行
  1. 运行php脚本,但是未输出信息,检测会看到状态码为500,说明有错误
代码语言:javascript
复制
[root@hf-01 php-fpm.d]# curl -x127.0.0.1:80 test.com/sleep.php
[root@hf-01 php-fpm.d]# curl -x127.0.0.1:80 test.com/sleep.php -I
HTTP/1.1 500 Internal Server Error
Server: nginx/1.12.1
Date: Tue, 09 Jan 2018 21:47:48 GMT
Content-Type: text/html; charset=UTF-8
Connection: keep-alive
X-Powered-By: PHP/5.6.30

[root@hf-01 php-fpm.d]# 
  1. 可以查看错误日志,但有更简单的方法就是打开它的配置文件
代码语言:javascript
复制
[root@hf-01 php-fpm.d]#  vim /usr/local/php-fpm/etc/php.ini

搜索 /display ,找到display_errors

将display_errors = Off 改为display_errors = On
  1. 打开display_errors之后,就可以在浏览器上查看到具体的错误是什么
  2. 重启php
代码语言:javascript
复制
[root@hf-01 php-fpm.d]# /etc/init.d/php-fpm reload
Reload service php-fpm  done
[root@hf-01 php-fpm.d]# 
  1. 检查错误,会看到语法错误,有可能是逗号,分号写的不对
代码语言:javascript
复制
[root@hf-01 php-fpm.d]# curl -x127.0.0.1:80 test.com/sleep.php
<br />
<b>Parse error</b>:  syntax error, unexpected 'slow' (T_STRING), expecting ',' or ';' in <b>/data/wwwroot/test.com/sleep.php</b> on line <b>2</b><br />
[root@hf-01 php-fpm.d]# 
  1. 检查sleep.php文件,发现里面使用的中文标点,更改后重启配置
代码语言:javascript
复制
[root@hf-01 php-fpm.d]# vim /data/wwwroot/test.com/sleep.php

<?php
echo "test slow log";
sleep(2);
echo "done";
?>
保存退出
[root@hf-01 php-fpm.d]# /etc/init.d/php-fpm reload
Reload service php-fpm  done
[root@hf-01 php-fpm.d]# 
  1. 再来测试,访问成功,会看到访问的时候停顿了几秒
代码语言:javascript
复制
[root@hf-01 php-fpm.d]# curl -x127.0.0.1:80 test.com/sleep.php
test slow logdone[root@hf-01 php-fpm.d]# 
  1. 查看是否生成了慢日志
代码语言:javascript
复制
[root@hf-01 php-fpm.d]# cat /usr/local/php-fpm/var/log/www-slow.log 

[10-Jan-2018 06:02:21]  [pool www] pid 3442
script_filename = /data/wwwroot/test.com/sleep.php        //提示:是哪个脚本慢
[0x00007f37c5f7c298] sleep() /data/wwwroot/test.com/sleep.php:3    //提示:是脚本的第三慢
[root@hf-01 php-fpm.d]# 
  1. 这个就是慢执行日志的功效
  2. 在遇到php网站访问慢的时候,就可以去查看慢日志
  3. 查看www.conf
代码语言:javascript
复制
[root@hf-01 php-fpm.d]# cat www.conf
[www]
listen = /tmp/php-fcgi.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024
request_slowlog_timeout = 1    //一般写两秒,很多脚本都会超过一秒
slowlog = /usr/local/php-fpm/var/log/www-slow.log
[root@hf-01 php-fpm.d]# 
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • php-fpm慢执行日志目录概要
  • php-fpm慢执行日志
相关产品与服务
轻量应用服务器
轻量应用服务器(TencentCloud Lighthouse)是新一代开箱即用、面向轻量应用场景的云服务器产品,助力中小企业和开发者便捷高效的在云端构建网站、Web应用、小程序/小游戏、游戏服、电商应用、云盘/图床和开发测试环境,相比普通云服务器更加简单易用且更贴近应用,以套餐形式整体售卖云资源并提供高带宽流量包,将热门软件打包实现一键构建应用,提供极简上云体验。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档