"); //-->
问题背景:在测试环境下点击项目的某个页面php-cgi.exe就会引发zend_mm_heap corrupted问题,导致页面功能不正常。
百度上找到的结果不多,看了Stack Overflow上面的讨论大都是通过修改php.ini配置文件解决问题,然后我按照上面说的一条条去改也还是会出现这个问题。
我的解决思路是:首先对比排查,生产环境上是没有这个问题的,而测试环境的项目代码和生产环境相同,所以是代码引发这个问题的可能性非常小,然后我通过一步步断点调试(目的缩小还原BUG的范围),初步推断可能是该页面输出浏览器的HTML代码过多导致zend内存管理的崩溃(结合网上对这个问题总结是根本原因是zend memory manager的 问题,这也可从字面意思猜测),而为什么会引发zend 内在管理崩溃是个关键,照理说如果是某段代码引发的应该可以断点调试出来(我断点调试结果是:当代码超过一定行数就会引发这个问题,而不是因为特定的某行代码引起),而且同样布署在生产环境的代码也该出现这个问题才是,所以最可能的问题是生产环境的php版本或者配置不同,而php.ini配置无论我怎么改,按照网上说的增大output_buffering= value 的值也没解决问题,所以我问了同事(负责发布到生产环境)生产环境上的php版本,得知生产环境的php是5.3的,到这个理所当然可以推测有可能是php版本不同,可能是低版本php的BUG所引发,而后通过升级php版本为5.3.5,该问题得到顺利解决。
总结:解决问题的思路和方向很重要,一步步排查缩小问题范围和断点调试是解决编程问题的好方法。
*博客内容为网友个人发布,仅代表博主个人观点,如有侵权请联系工作人员删除。