来源:自学PHP网 时间:2014-11-27 20:45 作者: 阅读:次
[导读] 如果不重启web服务器进行代码调试,总发现在session_start()的时候就不能进行下去了,问题原因后来终于明白了:因为浏览器发送的请求还是在web服务器中建立了线程进行了请求的处理,由于...
PHP session_start()很慢问题分析与解决办法最近在做东西的时候发现一个问题,有一个接口挂了,然后进行测试访问地址的时候,浏览器就一直处于等待响应的状态,怎么访问都不行,只有重启web服务器才行。 如果不重启web服务器进行代码调试,总发现在session_start()的时候就不能进行下去了,问题原因后来终于明白了:因为浏览器发送的请求还是在web服务器中建立了线程进行了请求的处理,由于session是在服务器端存储,而浏览器处于等待响应的状态就是表明了web服务器正在处理你的请求,但是由于响应超时时间很长,你也许进行了下一次的调试。 在上一个请求还未死亡之前,它一直占用着你的session资源,而session资源是不能共享的,你再次请求的就一直会在等待session资源的获取,也就是说只有等你上一个请求结束的时候你才能正常获取session资源并且进入代码的解析,以前发现PHP页面调用session_start()方法时很慢,甚至会用上几十秒钟,现在终于发现原因。 解决办法:因为session使用文件,多个请求时会锁住Session文件,尽量在不用Session时尽早释放Session.使用 session_write_close()方法,例如:
|
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com