资讯专栏INFORMATION COLUMN

php利用fastcgi_finish_request实现非阻塞及相关拓展

mudiyouyou / 848人阅读

摘要:基本应用介绍冲刷所有响应的数据给客户端此函数冲刷所有响应的数据给客户端并结束请求。需要长时间处理的代码处理完成后删除进程记录文件参考非阻塞实现方法

前言

在实际项目中经常会有这样的需求,对于前端发过来的请求,需要在后端进行长时间的处理,但为了让使用者有更好的体验,为了让PHP在后端处理长时间任务时不阻塞,快速响应页面请求,因此在这里对fastcgi_finish_request的应用进行总结归纳。当然php实现非阻塞的方式有很多种,比如异步脚本、swoole,但个人认为fastcgi_finish_request最为简单方便。

基本应用 fastcgi_finish_request介绍

(PHP 5 >= 5.3.3, PHP 7)

fastcgi_finish_request — 冲刷(flush)所有响应的数据给客户端

boolean fastcgi_finish_request ( void )

此函数冲刷(flush)所有响应的数据给客户端并结束请求。 这使得客户端结束连接后,需要大量时间运行的任务能够继续运行。

返回值

成功时返回 TRUE, 或者在失败时返回 FALSE

注意问题

PHP 与 Web 服务器使用了PHP-FPM(FastCGI进程管理器),那通过fastcgi_finish_request() 函数能马上结束会话,而 PHP 线程可以继续在后台运行。也就是说只针对php-fpm的进程管理方式才能使用该函数

只要代码运行到这个位置,就已经断开请求返回参数给客户端了。接下来的代码都和客户端没有关系了。也就是说对于输出在页面的内容必须放在fastcgi_finish_request函数之前

fastcgi_finish_request()结束客户端连接之后,运行时间依然会受max_execution_time超时时间的影响,也就是说如果预计到代码在后端执行时间比较久,还是要设定set_time_limit(0)

在高并发下执行时间过久也会导致fastcgi进程不够用,不能及时释放,就会爆502错误了。

应用
echo "program start...";

file_put_contents("/tmp/garylog.log","start-time:".date("Y-m-d H:i:s")."
", FILE_APPEND);

fastcgi_finish_request();sleep(1);

// set_time_limit(0);
// sleep(150);

$num = 25;
$num += 1;
sleep(5);
echo "debug...";
file_put_contents("/tmp/garylog.log", "start-proceed:".$num.",时间".date("Y-m-d H:i:s")."
", FILE_APPEND);

sleep(10);

file_put_contents("/tmp/garylog.log", "end-time:".date("Y-m-d H:i:s")."
", FILE_APPEND);

运行测试

兼容非php-fpm

从代码的可移植性讲的话, 可以在代码中附上如下代码:

    if (!function_exists("fastcgi_finish_request")) {
          function fastcgi_finish_request()  {
          }
    }

不会造成代码部署在非fpm环境下造成问题.

保证进程单一运行

对于上面说到的问题:在高并发下执行时间过久也会导致fastcgi进程不够用,不能及时释放。同时我们的需求仅仅是为了起到触发的作用,并不需要每次运行,那么可以考虑使用下面的方法,避免重复占用进程。

 
$processId = realpath(__FILE__) . "-" . get_class($this);
$filename = md5($processId);
$file = "/tmp/".$filename;
if(!file_exists($filename)){
    file_put_contents($file, getmypid());
}else{
    return true; 
}


## do somthing 需要长时间处理的代码

//处理完成后删除进程id记录文件
unlink($file);
参考

PHP非阻塞实现方法

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/29306.html

相关文章

  • php利用fastcgi_finish_request实现阻塞相关拓展

    摘要:基本应用介绍冲刷所有响应的数据给客户端此函数冲刷所有响应的数据给客户端并结束请求。需要长时间处理的代码处理完成后删除进程记录文件参考非阻塞实现方法 前言 在实际项目中经常会有这样的需求,对于前端发过来的请求,需要在后端进行长时间的处理,但为了让使用者有更好的体验,为了让PHP在后端处理长时间任务时不阻塞,快速响应页面请求,因此在这里对fastcgi_finish_request的应用进...

    Meils 评论0 收藏0
  • php利用fastcgi_finish_request实现阻塞相关拓展

    摘要:基本应用介绍冲刷所有响应的数据给客户端此函数冲刷所有响应的数据给客户端并结束请求。需要长时间处理的代码处理完成后删除进程记录文件参考非阻塞实现方法 前言 在实际项目中经常会有这样的需求,对于前端发过来的请求,需要在后端进行长时间的处理,但为了让使用者有更好的体验,为了让PHP在后端处理长时间任务时不阻塞,快速响应页面请求,因此在这里对fastcgi_finish_request的应用进...

    xcold 评论0 收藏0
  • 使用XHProf分析PHP性能瓶颈(一)

    摘要:输出的性能数据中添加数据。中间是要分析的代码。是一个绘制图形的工具,可以更为直观的让你查看性能的瓶颈。这样所有使用该环境的都会生效。这样仅该项目生效。 安装xhprof扩展 wget http://pecl.php.net/get/xhprof-0.9.4.tgz tar zxf xhprof-0.9.4.tgz cd xhprof-0.9.4/extension/ sudo phpi...

    pkwenda 评论0 收藏0
  • 后端知识拓展 - 收藏集 - 掘金

    摘要:阻塞,非阻塞首先,阻塞这个词来自操作系统的线程进程的状态模型网络爬虫基本原理一后端掘金网络爬虫是捜索引擎抓取系统的重要组成部分。每门主要编程语言现未来已到后端掘金使用和在相同环境各加载多张小图片,性能相差一倍。 2016 年度小结(服务器端方向)| 掘金技术征文 - 后端 - 掘金今年年初我花了三个月的业余时间用 Laravel 开发了一个项目,在此之前,除了去年换工作准备面试时,我并...

    CoderBear 评论0 收藏0
  • 后端知识拓展 - 收藏集 - 掘金

    摘要:阻塞,非阻塞首先,阻塞这个词来自操作系统的线程进程的状态模型网络爬虫基本原理一后端掘金网络爬虫是捜索引擎抓取系统的重要组成部分。每门主要编程语言现未来已到后端掘金使用和在相同环境各加载多张小图片,性能相差一倍。 2016 年度小结(服务器端方向)| 掘金技术征文 - 后端 - 掘金今年年初我花了三个月的业余时间用 Laravel 开发了一个项目,在此之前,除了去年换工作准备面试时,我并...

    Carl 评论0 收藏0

发表评论

0条评论

mudiyouyou

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<