今天群里有朋友说他的遇到一个有趣的问题:

一个PHP页面的执行时间比较长(15秒左右),而只要这个页面没有执行完毕,其他的页面访问都是长时间加载状态,只有那个页面执行完毕了,剩下的页面才能打开。

这是什么情况呢,经过查看,两个页面都设计到了SESSION操作,示例代码如下:

页面一:

页面二:

访问页面一地时候同时访问页面二,你会发现页面二会一直保持加载状态直到页面一执行完毕。

问题的原因是什么呢?

答案是PHP的SESSION机制在作怪,PHP只会在页面代码执行完毕之后才会把SESSION数据写入到文件中,页面不执行完毕,对应的 SESSION文件一直都保存着锁定状态,而其他的页面要访问这个SESSION文件就只能保持等待状态,这就是为什么页面二需要等待页面一执行完毕之后 才执行。

知道原因后,我们应该如何解决这个问题呢?

答案很简单,PHP已经在内核中提供了相关接口:函数 session_write_close

函数官方文档的描述如下:

Session data is usually stored after your script terminated without the need to call session_write_close(), but as session data is locked to prevent concurrent writes only one script may operate on a session at any time. When using framesets together with sessions you will experience the frames loading one by one due to this locking. You can reduce the time needed to load all the frames by ending the session as soon as all changes to session variables are done.

Session数据通常在你的脚本结束后自动保存而不需要调用session_write_close函数。但是session为了避免数据被同时 写入将文件锁定住以保证每次只有一个脚本可以访问文件。当你在用框架页面同时访问SESSION的时候将会遇到因为文件锁定而出现的框架持续加载情况。你 可以在处理完SESSION变量后立即使用这个函数减少多个框架的加载时间。

像前面的问题,我们可以直接在操作完SESSION数据后调用session_write_close函数立即写入session数据,这样就不会影响到其他页面的正常运行。代码如下:

原文:http://be-evil.org/how-to-fix-php-session-page-keep-loading-issue.html

更多相关文章

  1. 阅读使用JavaScript生成的页面
  2. jQuery ajax调用不会调用我的php页面
  3. php计算几分钟前、几小时前、几天前的几个函数
  4. PHP打印输出数组内容及结构函数print_r与var_dump
  5. mySQL库编码,PHP页面编码和mysql_query("set names 'GBK'")编码问
  6. mysql利用st_distance函数查询附近的点的功能
  7. 我需要PHP页面显示mysql数据库中的BLOB图像
  8. mySql中SUBSTRING_INDEX函数用法
  9. 在H2数据库中插入时间——函数“PARSEDATETIME”未找到

随机推荐

  1. 2018年度总结-Flag果然不能随便立
  2. 思科实验
  3. java最全面试题来啦,看到了还担心面试过不
  4. Flask vs Django,Python Web 开发用哪个框
  5. 重磅!Github 私有仓库免费开放
  6. 【开发者必看】移动应用趋势洞察白皮书-
  7. VUE~~~table编辑列功能
  8. 不会时间序列预测?不要紧,大神来教你
  9. 12条经验,让你在机器学习的路上避免很多坑
  10. 全息金融行业数据安全解决方案