如果 PHP 与 Web 做事器利用了 PHP-FPM(FastCGI 进程管理器),那通过 fastcgi_finish_request() 函数能立时结束会话,而 PHP 线程可以连续在后台运行。

echo \公众program start...\"大众;file_put_contents('log.txt','start-time:'.date('Y-m-d H:i:s'), FILE_APPEND);fastcgi_finish_request();sleep(1);echo 'debug...';file_put_contents('log.txt', 'start-proceed:'.date('Y-m-d H:i:s'), FILE_APPEND);sleep(10);file_put_contents('log.txt', 'end-time:'.date('Y-m-d H:i:s'), FILE_APPEND);

从输出结果可看到,页面打印完program start...,输出第一行到 log.txt 后会话就返回了,所往后面的 debug... 不会在浏览器上显示,而 log.txt 文件能完全地吸收到三个完成韶光。

2 利用 fsockopen()

phpforkPHP非壅塞实现办法 Java

利用 fsockopen() 打开一个网络连接或者一个Unix套接字连接,再用 stream_set_blocking() 非壅塞模式要求:

$fp = fsockopen(\"大众www.example.com\公众, 80, $errno, $errstr, 30);if (!$fp) { die('error fsockopen');}// 转换到非壅塞模式stream_set_blocking($fp, 0);$http = \公众GET /save.php / HTTP/1.1\r\n\公众;$http .= \"大众Host: www.example.com\r\n\公众;$http .= \公众Connection: Close\r\n\r\n\"大众;fwrite($fp, $http);fclose($fp);

3 利用 cURL

利用cURL中的 curl_multi_ 函数发送异步要求

$cmh = curl_multi_init();$ch1 = curl_init();curl_setopt($ch1, CURLOPT_URL, \"大众http://localhost/\公众);curl_multi_add_handle($cmh, $ch1);curl_multi_exec($cmh, $active);echo \"大众End\n\"大众;

4 利用 Gearman/Swoole 扩展

Gearman 是一个具有 php 扩展的分布式异步处理框架,能处理大批量异步任务。

Swoole 最近很火,有很多异步方法,利用大略。

5 利用缓存和行列步队

利用redis等缓存、行列步队,将数据写入缓存,利用后台操持任务实现数据异步处理。

这个方法在常见的大流量架构中该当很常见吧

6 调用系统命令

极度的情形下,可以调用系统命令,可以将数据传给后台任务实行,个人觉得不是很高效。

$cmd = 'nohup php ./processd.php $someVar >/dev/null &';`$cmd`

7 利用 pcntl_fork()

安装 pcntl 扩展,利用 pcntl_fork() 天生子进程异步实行任务,个人以为是最方便的,但也随意马虎涌现僵尸进程。

$pid = pcntl_fork()if ($pid == 0) { child_func(); //子进程函数,主进程运行} else { father_func(); //主进程函数}echo \"大众Process \公众 . getmypid() . \"大众 get to the end.\n\"大众; function father_func() { echo \"大众Father pid is \"大众 . getmypid() . \"大众\n\公众;}function child_func() { sleep(6); echo \"大众Child process exit pid is \公众 . getmypid() . \"大众\n\"大众; exit(0);}