php fpm慢执行日志,php-fpm的一次慢执行日志slow log

当线上环境出现响应超时,通过检查MySQL慢查询日志未找到问题时,发现是PHP的问题。通过开启PHP的slowlog,定位到pconnect()函数因连接redis失败导致延迟。解决方案是为新服务器安装证书以连接redis。开启PHP慢日志的配置方法包括设置request_slowlog_timeout、slowlog和request_terminate_timeout参数。
摘要由CSDN通过智能技术生成

测试环境、预发布环境经过QA多番测试没有遇到问题,但在一次上线过程中,在线上环境出现20秒的响应超时,这个毫无疑问,环境问题。

尽管线上数据量大,可Mysql以不至于慢到20秒,而且发现每次技术都是20.01~20.04秒之间,相差不到一秒钟,mysql也不至于这么均匀,在好奇心下,运维大神配合查了一下Mysql慢查询日志,发现没有超时的sql日志,那这有可能就是php这边出现的问题,可一想,逻辑执行也总不能这么慢。想打日志一步步跟踪,这种方式有点慢。mysql 有慢查询,同样咱php也有慢日志。

使用php slow方式确实找到了问题所在,截图如下:

54bacc69f300991fa0a7f1e660be226a.png

pconnect()原因导致,这个我当然清楚,是因为连接redis失败导致。 因为是在新的服务器,所以连接不上核心项目的redis服务器,最终还是运维大神安装的证书解决。

解决了问题后,大概了解如下:

一、开启slow log方法:

如果你使用php-fpm来管理php的话,你可以通过如下方法开启:

首先打开 php-fpm.conf 配置文件。

vim /usr/local/php/etc/php-fpm.conf

PHP 5.3.3 之前设置如下:

5s

< value name="slowlog">logs/php-fpm-slowlog.log

PHP 5.3.3 之后设置以下如下:

request_slowlog_timeout = 5s

slowlog = /usr/local/php/var/log/php-fpm-slowlog.log

request_terminate_timeout = 10s

说明:

request_slowlog_timeout 是脚本超过多长时间,就可以记录到日志文件;

slowlog 是日志文件的存储路径;

request_terminate_timeout 将执行时间太长的进程直接终止;

二、slow log如何使用?

开启后,如果有脚本执行超过指定的时间,就会在指定的日志文件中写入类似如上图所示,执行格式:pid  进程号

日志说明:

script_filename 是入口文件

curl_exec() : 说明是执行这个方法的时候超过执行时间的。

exfilter_curl_get() :说明调用curl_exec()的方法是exfilter_curl_get() 。

每行冒号后面的数字是行号。

开启后,在错误日志文件中也有相关记录...去日志查看就可以了

标签:slow,log,fpm,slowlog,日志,php

来源: https://www.cnblogs.com/wt645631686/p/12173664.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值