ajax已并发请求php,但php-fpm却没有如预期fork出多个进程来处理?

发布于 2022-09-04 05:45:07 字数 740 浏览 23 评论 0

项目业务中有同时发起ajax异步请求相关业务接口数据的逻辑,一直以来总觉得比预期的并发处理慢得多,最近抽空做了下纯净测试才发现,原来一个个异步请求虽然是同时由浏览器发起了,但等待响应确实阻塞在排队的(这完全浪费了php-fpm的多进程并发处理啊)。下面举例说明,比如ajax同时异步请求test.php及test2.php,js代码如下:

$.get("test.php");
$.get("test2.php");

test.php中代码如下:

sleep(1);

test2.php中代码如下:

sleep(1);

测试发现(Chrome F12打开网络异步XHR请求)2个ajax请求是先后执行同时发起的,但请求test2.php的响应却被阻塞等待1秒后,自己再执行需要1秒后得到成功响应200状态。此刻查看php-fpm进程数状态:

pstree -ap |grep php-fpm |grep -v grep

发现除了php-fpm管理进程外,始终只有另外一个php-fpm子进程(不用考虑php-fpm进程数方面的配置,这个已做测试正确的配置),但按道理来说应该是有另外2个php-fpm子进程的(另外测试发现是这个结果跟是否是请求同一php文件或者同一URL都无关,结果都一样阻塞)。我猜想,是否针对同一站点域名同一IP的请求,php-fpm总是阻塞的只开出一个进程来处理?有大神能给出权威的解释吗?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

爱你是孤单的心事 2022-09-11 05:45:07

看php的进程数

遥远的绿洲 2022-09-11 05:45:07

浏览器跑的javascript只有一个线程,所以肯定是先后处理的。轮子哥说的。你可以产看webserver日志,请求应该是先后到来的

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文