php里面的session lock

早上看到有网友留言说评论提交之后,没有然后……我大概get到了意思,就是ajax提交之后被block住了。我第一反应可能是缓存导致的,但后来一想,并没有在comment的脚本里加缓存啊。于是中午排查了一下,发现了两个可能,一个是session lock,另一个是smtp邮件服务有问题。

我把smtp发送改为了ssl模式,端口是465. 还到阿里云安全组里面去添加了规则。回来测试了一下,发邮件OK了。

session lock这个话题比较专业,这里有一篇文章可以大概了解为什么一个session会把请求block住。简单的说就是你代码里面一个简单的$_SESSION['xxx'] = 'xxx',实际上php要去写入文件,如果同时多个请求都去执行这段代码,那么后面的请求需要等前面的请求把这事儿干完了才能继续,不然只能等着。解决的办法就是在每一个赋值语句后面加上

session_write_close();

这个语句可以在你的php程序执行完之前提前把session lock解锁。如果不执行,那么PHP要等到你当前这个进程执行完毕才会unlock。而在我这次案例里面,因为发邮件的问题导致我的PHP进程被block住,所以如果在发邮件之前有一个session写入,那么其它的要写入session的程序就会被block住,比如我在后台提交了一个请求,要写入某个session,前台某个提交也要写入这个session,那么在后台那个请求执行完毕之前,前台的提交就会block在写入session那个地方。