"); //-->
问题背景:在测试环境下点击项目的某个页面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,该问题得到顺利解决。
总结:解决问题的思路和方向很重要,一步步排查缩小问题范围和断点调试是解决编程问题的好方法。
专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们
相关推荐
传输线理论与阻抗匹配
从直流到500kHz的100W放大电路
机器人开发平台MOVE上线:打通EBV生态系统,助力整机系统设计
SH-Stick试用套件
如何应用英飞凌新一代G2 CoolSiC™ MOSFET 提升系统效率
串扰仿真的疑问
蓝牙设备今年将出货59亿台,我国蓝牙产品认证数量世界第一
PDIUSBD12 u盘设计:给入门者(1)
大难题,博士也答不出来
瑞萨电子工具E1
超大规模集成电路--系统和电路的设计原理
SiC MOSFET 体二极管特性及死区时间选择
输出电流达10A的功率放大电路
应用方案 | AI Agent大时代,南芯助力AI PC CPU/GPU提高效能
RX Stick套件
迈向SDV时代:安森美以10BASE-T1S方案加速车载网络统一进程
瑞萨电子Minicube2
谷歌母公司财报:谷歌云业务营收狂飙,同比增长 63%
台积电SoIC路线图:2029芯片堆叠迈向4.5μm间距,全力支撑AI算力
关于arm7
大难题,博士也答不出来
超大规模集成电路微细加工技术
电子分频放大电路
超大规模集成电路系统导论
全球首家AI硅光子芯片上市公司正式登陆港交所
300W高保真放大电路
韩研究团队开发玻璃基板超快激光布线技术,瞄准CPO瓶颈突破
V850 Stick套件
模拟卡拉0K伴唱放大电路
vxworks增加一个设备,总是有错啊?