简介:这是php APC 造成的session无法保存bug及解决方法的详细页面,介绍了和php,有关的知识、技巧、经验,和一些php源码等。
class='pingjiaF' frameborder='0' src='http://biancheng.dnbcw.info/pingjia.php?id=335086' scrolling='no'>APC对 php 脚本的加速效果是明显的,基本可以将 php-fpm 服务器负载能力提高到 2 倍,所以在生产环境中,需要尽可能使用 APC 来加速 php 脚本。
这是我通过web bench 压力测试得出的结论,而在生产环境中,使用 APC 之后,脚本的执行速度确实有提高 (可能达到10-20% )
生产环境中使用
session_set_save_handler
将
session保存到
MySQL
内存表中,并安装了
APC
扩展,就发现无法保存
session
,后经过反复排查是因为
APC
引起,从网上找到的原因分析:
写道
一般的环境Session 是静态编译进 PHP 的 , 所以 Session 模块一定先于动态编译进 PHP 的 APC 被载入 , 也就是说 , 在请求关闭时期 , APC 的请求关闭函数 , 一定会先于 Session 的请求关闭函数被调用 .
所以, 当 Session 的请求关闭函数调用的时候 , 执行环境的 Class Table 已经为空 , 当然也就会抛出类找不到的 fatalerror 了。
所以, 当 Session 的请求关闭函数调用的时候 , 执行环境的 Class Table 已经为空 , 当然也就会抛出类找不到的 fatalerror 了。
--实质上数据库类的实例已经被销毁,引发了无法看到的错误。
对此解决办法非常简单:
在php
程序执最后,手工调用
session_write_close();
或在register_shutdown_function 定义的函数中调用也可。
但是如果使用php 默认的文件存储 session 机制,则不存在此问题。