由于PHP的Apache段错误

时间:2013-09-26 12:23:10

标签: php apache segmentation-fault

当运行特定的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机器之间的更新版本或不同配置造成的。

0 个答案:

没有答案