当运行特定的PHP代码时,我在Apache2中遇到了分段错误。确切的错误是Program terminated with signal 11, Segmentation fault.
启用核心转储并使用sudo gdb apache2 -core /tmp/apache2-gdb-dump/core
分析核心转储后,我得到了可以在http://pastebin.com/WetihWU0获得的结果。显然spl_array.c
出了问题。
我将其缩小为一段使用Propel 1.7生成的方法的PHP代码。这段代码删除了特定类的交叉引用条目:
foreach($record->getCrossReferences() as $crossReference) {
$record->removeCrossReference($crossReference);
}
如果我在循环外调用removeCrossReference()
,则不会发生错误。怪异的呃?
由于PHP在某些c代码上崩溃,我发现很难获得产生segfault的最小代码示例。有谁碰巧知道导致段错误的原因是什么?或者也许给我一些指向获取最小代码示例的指针?我不认为PHP.org上的人在没有最小代码样本的情况下接受错误报告。
我使用的版本:
$ php -v
PHP 5.3.10-1ubuntu3.8 with Suhosin-Patch (cli) (built: Sep 4 2013 20:05:42)
Copyright (c) 1997-2012 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2012 Zend Technologies
with Xdebug v2.1.0, Copyright (c) 2002-2010, by Derick Rethans
$ /usr/sbin/apache2 -v
Server version: Apache/2.2.22 (Ubuntu)
Server built: Jul 12 2013 13:38:21
Propel version 1.7.0-dev
有趣的是,我还有一台带有较新版Apache和PHP的Arch机器。在这台机器上不会发生故障。但我不知道这是由于Arch和Ubuntu机器之间的更新版本或不同配置造成的。