遇到一个很奇葩的现象,test.php:(访问后隔10s打印时间)
<?php
sleep(10);
echo date('Y-m-d H:i:s', time());
同一个浏览器打开2个标签页,同时访问apache上的这个页面,为什么第2个页面永远会比第一个页面晚10s钟,在不同浏览器里同时打开就几乎同时输出。
难道是php处理同一浏览器的2个相同请求,不并发而是先后执行,这是为什么呢?
把apache换成nginx也是如此,这是php本来的特性还是哪设置的问题?
遇到一个很奇葩的现象,test.php:(访问后隔10s打印时间)
<?php
sleep(10);
echo date('Y-m-d H:i:s', time());
同一个浏览器打开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能及时响应,即使处理没有完成。
<?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');
一个浏览器终端你连接服务器终端会产生一个session_id{lock};服务期代码(echo "立即输出" ;sleep(100);)你用chrome打开一个页签访问服务立即得到“立即输出”内容,然后在用chrome打开第二个页签访问服务会一直卡在那里记载,再用safari访问同一地址会立即得到“立即输出”内容;
1 回答4.1k 阅读✓ 已解决
3 回答1.9k 阅读✓ 已解决
2 回答2.3k 阅读✓ 已解决
2 回答2.2k 阅读
1 回答1.4k 阅读✓ 已解决
800 阅读
651 阅读
@by快乐家园 所说的浏览器限制正对我的电脑 -- 也是chrome。
换做双开控制台,然后用两个curl去访问,结果就是几乎同时返回。
为什么会有浏览器限制呢,chrome应该是多进程的呀?
-- 初步猜测是因为cookie的问题,因为刚刚清掉所有cookie后,然后再访问就是同时返回了
为什么cookie会导致无法并行呢?
-- 检查下php的配置,发现
session.auto_start = 1
,修改为0,重启下服务器,再访问就同时返回了;-- session会有锁,正是这个锁导致第一个请求结束后,第二个请求才真正开始。
原因可能有多方面,LZ可以检查下
session.auto_start