产生的原因
var democ=new Vue({
el:'#list',data:{
her:'',listData:[],listurl:ALLURL+'/index.PHP/Wap/Read/indexlist'
},created:function(){
this.listDll()
},methods:{
listDll:function(){
var that=this;
that.$http({
method:'GET',url:this.listurl
}).then(function(response){
//console.log(response.data)
var obj=JSON.parse(response.data);
this.her=ALLURL;
this.listData=obj.data;
},function(error){
})
}
}
});
$.get(ALLURL+'/index.PHP/Wap/Read/indexlist',function(res){
var obj=JSON.parse(res);
var Data=obj.data;
}
);
$.get(ALLURL+'/index.PHP/Wap/Read/cases',function(res){
var obj=JSON.parse(res);
var Data=obj.data;
}
);
/
$.get(ALLURL+'/index.PHP/Wap/Read/active',function(res){
var obj=JSON.parse(res);
var Data=obj.data;
}
);
$.get(ALLURL+'/index.PHP/Wap/Read/record',function(res){
var obj=JSON.parse(res);
var Data=obj.data;
}
);
多个界面请求,经执行后发现需要执行10秒左右时间,初以为是PHP与数据库交互花的时间过多导致,其实不然,真正原因是@H_502_9@session文件锁导致。
当你向服务器发送一个Ajax请求时,PHP脚本也开启了session_start(),它的调用会锁定PHP的session文件。
你可能已经知道,PHP默认会把session数据存储在服务器上的文件中。因为仅仅只有一个PHP请求能改变同一个session文件,两个同时的PHP请求可能会造成典型的文件锁条件,因此,任何一个其他由PHP调用的对于同一个用户的session_start()请求将不得不等到第一个请求结束。
现在,大部分PHP框架会首先在主文件中使用session_start()。因此,如果你正在使用会调用session_start()的框架或者函数库,将会造成session文件锁,对于使用同一个浏览器的相同用户,这将延迟同时发送的Ajax请求。
简言之同一个客户端同时并发发送多个请求(如ajax在页面同时发送多个请求),且脚本执行时间较长,就会导致session文件阻塞,影响性能。因为对于每个请求,PHP执行session_start(),就会取得文件独占锁,只有在该请求处理结束后,才会释放独占锁。这样,同时多个请求就会引起阻塞。
解决方案
@H_502_9@1.不用session
原文链接:https://www.f2er.com/ajax/160522.html