php-fpm特色功能

fastcgi_finish_request() 

这个特性可以提高一些 php 请求的处理速度。

例如程序步骤是:

1.程序处理页面逻辑

2.保存数据

3.返回结果

可以改成

1.处理逻辑

2.返回结果

fastcgi_finish_request() 

3.保存数据 //调用这个函数,会强制处理进程返回结果,并将后续逻辑在后台执行,不影响前端用户体验

 

request_slowlog_timeout


范围: php-fpm.conf 选项

分类: 方便

这个选项能让你跟踪执行缓慢的脚本并把他们连同调用栈一起记录再日志文件中。例如如下设置:

    <value name="request_slowlog_timeout">5s</value>
    <value name="slowlog">logs/slow.log</value>

记录的 slow.log 可能是这个样子:


Sep 21 16:22:19.399162 pid 29715 (pool default)
script_filename = /local/www/stable/www/catalogue.php 
[0x00007fff23618120] mysql_query() /srv/stable/common/Database/class.MySQLRequest.php:20 
[0x00007fff23618560] getResult() /srv/stable/common/Database/class.Facade.php:106 
[0x00007fff23618aa0] query() /srv/stable/common/mysite.com/ORM/class.UsersMapper.php:99 
[0x00007fff23618d60] resolveByID() /srv/stable/common/mysite.com/ORM/class.User.php:629 
[0x00007fff236193b0] getData() /srv/stable/common/class.DataEntity.php:90
[0x00007fff236195d0] load() /srv/stable/common/mysite.com/ORM/class.User.php:587 
[0x00007fff23619a00] getIsHidden() /srv/stable/common/mysite.com/class.User.php:42 
[0x00007fff2361a470] getName() /local/www/stable/www/catalogue.php:41

同时,在 error.log 中保存了如下记录:


Sep 21 16:22:19.399031 [WARNING] fpm_request_check_timed_out(), line 135: child 29715, script '/local/www/stable/www/catalogue.php' (pool default) executing too slow (5.018002 sec), logging

正如你再例子中看到的,脚本运行了 5 秒以上,并很可能是由于 mysql 响应慢造成的(top backtrace)。 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值