Heim  >  Artikel  >  Backend-Entwicklung  >  php页面在同一浏览器打开不并发执行

php页面在同一浏览器打开不并发执行

WBOY
WBOYOriginal
2016-06-06 20:32:551618Durchsuche

遇到一个很奇葩的现象,test.php:(访问后隔10s打印时间)

<code><?php sleep(10);
echo date('Y-m-d H:i:s', time());
</code></code>

同一个浏览器打开2个标签页,同时访问apache上的这个页面,为什么第2个页面永远会比第一个页面晚10s钟,在不同浏览器里同时打开就几乎同时输出。

难道是php处理同一浏览器的2个相同请求,不并发而是先后执行,这是为什么呢?

把apache换成nginx也是如此,这是php本来的特性还是哪设置的问题?

回复内容:

遇到一个很奇葩的现象,test.php:(访问后隔10s打印时间)

<code><?php sleep(10);
echo date('Y-m-d H:i:s', time());
</code></code>

同一个浏览器打开2个标签页,同时访问apache上的这个页面,为什么第2个页面永远会比第一个页面晚10s钟,在不同浏览器里同时打开就几乎同时输出。

难道是php处理同一浏览器的2个相同请求,不并发而是先后执行,这是为什么呢?

把apache换成nginx也是如此,这是php本来的特性还是哪设置的问题?

假设你只开启了1个PHP-FPM工作进程,PHP-FPM执行sleep(10)时会睡眠10秒,后面的请求必须等待10秒后才能被处理,不管是不同的标签页还是不同的浏览器。而且sleep调用比较特殊,就算浏览器按Esc中断请求,PHP-FPM也不会停止sleep。

不能同时返回应该是浏览器的机制,而不是PHP的问题,对同一个资源发出请求,如果第一个请求未响应,浏览器应该就不会发出第二个请求。如果第一个请求能及时响应,第二个请求也就能及时发出,比如同时访问下面的脚本,两个请求几乎是同时返回的,其中flush能及时响应,即使处理没有完成。

<code><?php ob_start();
echo date('H:i:s').'<br />';
echo str_repeat(' ', 1024*4);
ob_flush();
flush();
ob_end_flush();
sleep(10);
echo date('H:i:s');
</code>

有可能是浏览器限制。某些浏览器是单线程。

@by快乐家园 所说的浏览器限制正对我的电脑 -- 也是chrome。
换做双开控制台,然后用两个curl去访问,结果就是几乎同时返回。

为什么会有浏览器限制呢,chrome应该是多进程的呀?
-- 初步猜测是因为cookie的问题,因为刚刚清掉所有cookie后,然后再访问就是同时返回了
为什么cookie会导致无法并行呢?
-- 检查下php的配置,发现session.auto_start = 1,修改为0,重启下服务器,再访问就同时返回了;
-- session会有锁,正是这个锁导致第一个请求结束后,第二个请求才真正开始。

原因可能有多方面,LZ可以检查下session.auto_start

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn