日期:2014-05-17  浏览次数:20542 次

php APC 造成的session无法保存bug及解决方法

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 了。
?

?

--实质上数据库类的实例已经被销毁,引发了无法看到的错误。

?

?

对此解决办法非常简单:

php 程序执最后,手工调用 session_write_close();

?

或在register_shutdown_function 定义的函数中调用也可。

?

但是如果使用php 默认的文件存储 session 机制,则不存在此问题。

?

?

?

?