最近在研究与迁移HHVM,在过程中遇到不少坑,比如遇到了fastcgi_finish_request这个函数问题。
fastcgi_finish_request是由FPM特供的一个函数,主要实现了在结束http请求之后,php-cgi仍然继续执行fastcgi_finish_request后面的代码,可以实现的一个简单的异步操作,具体使用可以参考之前的文章:《使用fastcgi_finish_request()提高请求响应速度》
在不断摸索之后,终于找到了HHVM下fastcgi_finish_request的替代方案,
HHVM 也提供了一个类似的函数:register_postsend_function
以上是HHVM官方的idl,对此函数的描述,它实现了类似fastcgi_finish_request的功能,由于官方wiki非常少,
在尝试之后,此函数的使用方式如下:
register_postsend_function是注册一个回调函数用于http请求结束时触发,参数类似call_user_func,
用法如下:
中第一个参数为回调函数,可以是一个匿名函数,也可以是预定义的函数,也可以是类的公共函数或静态函数,
后续的参数对应于传入回调函数的形参。
如:
或者:
以上两个例子中的$a对应于传入的形参$bar
在类中使用如下
使用注意:
因为register_postsend_function是注册回调函数,并且是在http结束之后才会触发,
并不像fastcgi_finish_request是直接在上下文中,
所以它并没有保持发起此函数时的上下文,回调函数里面的现场需要显式的还原,可以通过函数参数来还原现场。
20150624
使用fastcgi_finish_request()提高请求响应速度
PHP가 FastCGI 모드로 실행될 때, PHP-FPM은 fastcgi_finish_request라는 메서드를 제공합니다. 문서에 따르면 이 메서드는 요청 처리 속도를 향상시킬 수 있으며, 페이지 생성 후에 수행할 수 있는 처리가 있다면 이 메서드를 사용할 수 있습니다.이해를 돕기 위해 몇 가지 예제를 살펴보겠습니다:브라우저로 이 스크립트에 접근하면, 해당 문자열이 출력되지 않았지만 파일이 생성된 것을 확인할 수 있습니다. 이는 fastcgi_finish_request 호출 후 클라이언트 응답이 이미 종료되었지만, 서버 측 스크립트는 계속 실행되고 있음을 보여줍니다!이 특성을 적절히 활용하면 사용자 경험을 크게 향상시킬 수 있습니다. 다음은 또 다른 예제입니다:이 코드에서는 sleep을 사용하여 시간이 걸리는 작업을 시뮬레이션합니다. 브라우저에서 볼 때 차단되지 않지만 프로그램은 모두 실행되었으며, 자세한 내용은 로그를 확인하면 됩니다.마지막으로 한 가지 팁을 드리자면, Yahoo의 "웹사이트 속도 향상을 위한 모범 사례"에서 언급된 "버퍼를 일찍 플러시하기"는 PHP의 flush 메서드를 사용하여 내용을 가능한 빨리 클라이언트로 보내는 것을 의미합니다. 이는 이 글에서 소개한 fastcgi_finish_request와 약간 유사합니다.추가 설명: 이 메서드를 호출하면 응답을 보내고 연결을 닫습니다. 그러나 PHP 실행은 종료되지 않습니다. flush를 호출하거나 이전에 소개한 echo 가속화 방법과 비교하면, 이 방법이 더 확실합니다.또한 코드의 이식성을 고려하면 다음과 같은 코드를 추가할 수 있습니다:
phpecho 'start:'; fastcgi_finish_request(); /* response */ file_put_contents('log.txt', 'finish');
phpecho 'start:'; 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);
phpif (!function_exists("fastcgi_finish_request")) { function fastcgi_finish_request() { } }
피드 구독하기:
글 (Atom)