听起来可能有些茫然,我们通过几个例子来说明一下:
复制代码 代码如下:
<?
php echo '例子:';
fastcgi_finish_request();
echo 'to be, or not to be, that is the question.';
file_put_contents('log.txt', '生存还是毁灭,这是个问题。');
?>
通过浏览器(不是命令行!)运行此脚本,结果发现并没有输出相应的字符串,但却生成了相应的文件。由此说明在调用fastcgi_finish_request后,客户端响应就已经结束,但与此同时服务端脚本却继续运行!
合理利用这个特性可以大大提升用户体验,趁热打铁再来一个例子:
复制代码 代码如下:
<?php
echo '例子:';
file_put_contents('log.txt', date('y-m-d h:i:s') . " 上传视频\n", file_append);
fastcgi_finish_request();
sleep(1);
file_put_contents('log.txt', date('y-m-d h:i:s') . " 转换格式\n", file_append);
sleep(1);
file_put_contents('log.txt', date('y-m-d h:i:s') . " 提取图片\n", file_append);
?>
代码里用sleep模拟一些耗时的操作,浏览时没有被堵塞,程序却都执行了,具体看日志。
末了给您提个醒,yahoo在best practices for speeding up your web site中提到了flush the buffer early,也就是利用php中的flush方法把内容尽快发到客户端去,虽然表面上它和本文介绍的fastcgi_finish_request有些许的类似,但本质上完全不同,别混淆了。
转载附言: 我看了下这个方法, 在调用的时候, 会发送响应, 关闭连接. 但是不会结束php的运行. 相比调用flush, 或者我之前介绍的加速你的echo来说, 这个方法能更加干脆一些.
另外, 从代码的可移植性讲的话, 可以在代码中附上如下代码:
复制代码 代码如下:
if (!function_exists("fastcgi_finish_request")) {
function fastcgi_finish_request() { }
}
不会造成代码部署在非fpm环境下造成问题.
评论列表:
发布于 3天前回复该评论
发布于 3天前回复该评论
发布于 3天前回复该评论
发布于 2天前回复该评论
发布于 2天前回复该评论
发布于 2天前回复该评论
发布于 2天前回复该评论
发布于 1天前回复该评论