如何在php中使用session锁防止阻塞请求?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
问题:
php的session缺省用文件存储,当请求一个需要操作session的php文件(session_start()
)时,这个文件是会被第一个操作session的进程锁定,导致其他请求阻塞。其他请求会挂起在session_start()
直到session文件解锁。
解决:
由于锁定的session文件直到脚本执行结束或者session正常关闭才会解锁,为了防止大量的php请求(需要使用$_SESSION数据)被锁定,可以在写完session后马上关闭,这样就释放了锁。
关闭session:
session_write_close();
这个技巧非常管用,尤其对于一个处理时间长的脚本。并且这个函数只是关闭了写session,读还是可以的。
// session_start(); //可以读写session $_SESSION['latestRequestTime'] = time(); //关闭session session_write_close(); //读取session $twitterId = $_SESSION['twitterId'];
译注:
在php5.4以后,session_set_save_handler
支持了传递SessionHandlerInterface 的方式,第二个参数就是指定session_write_close()
作为回调方法的(缺省就是true),将函数 session_write_close()
注册为 register_shutdown_function()
函数。
用Memcache或者Redis做session的存储,是能解决“锁定”的问题,但处理不好会导致连接数标高(在session操作后如果有耗时操作,连接是不回收的,可以主动在session写操作完成后做session_write_close()
操作)
关于如何在php中使用session锁防止阻塞请求问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。