问题如下:
我在wroot目录下面有一个配置了虚拟域名的目录v.juhe.cn,然后在v.juhe.cn下面建立两个文件分别是test1.php和test2.php
在test1.php中代码是
exit("zheshiweishms");
在test2.php中代码是
sleep(10); echo 'nihao'; exit();
那么当我访问vv.juhe.cn/test2.php的时候会经过10s才会在浏览器出现nihao这个字符串,那么在这10s中,访问vv.juhe.cn/test1.php这个地址的时候会直到test2.php执行完毕只有才会响应,之前我在本地测试a项目的时候,发现a项目调用b项目的接口的时候也会出现阻塞的问题,当时的解决思路是不同的虚拟域名下面开启不同的端口,解决了这个问题,那么今天的这个问题我遇到是在我测试数据库的lock for update功能的时候偶然发现的,
我发现调用接口1和接口2
接口1中sql = select * from xxx where id=1 for update; sleep(10)
接口2中select * from xxx where id=2;
这样竟然也被锁了,难道是锁表了吗,后来就一直测试到了上面的代码,完全除去数据库的操作,只输出一句话,结果也发现出现了阻塞,那么就跟数据库没有关系了,最后在网上查到了解决的办法,就是在nginx.conf 的http模块配置中添加了(我有八个虚拟主机的配置,所以我这里开了八个端口)
upstream phpfastcgi_proxy { server 127.0.0.1:9000; server 127.0.0.1:9001; server 127.0.0.1:9002; server 127.0.0.1:9003; server 127.0.0.1:9004; server 127.0.0.1:9005; server 127.0.0.1:9006; server 127.0.0.1:9007; # 或更多…… }然后在nginx.conf和vhost目录下面的所有虚名域名下将
fastcgi_pass 127.0.0.1:9xxx;
改为:
fastcgi_pass phpfastcgi_proxy;
记住,是要所有的(包括虚拟主机上面的)都替换,这样就可以了;
但是,这样还有一个问题,当我在chrom浏览器访问同一个文件的时候,是做不到同时访问的,比如在test1,这个文件中代码如下
echo 'nihao'; sleep(20);
那么在浏览器中访问,会等待20s,代码改为:
echo 'nihao'; //sleep(20);此时在浏览器中另外打开一个窗口访问(同一个文件),还是要等到前面那次访问结束之后才能访问,但是如果在这等待的20s之内,你 换个浏览器,或者用postman测试工具进行访问的时候,是不需要等待的