记一次PHP“Segmentation fault”调试经历

遇到的问题:

在linux上安装php5.5.26、phalcon2.0扩展、xhprof扩展,均正常安装,并可单独运行。但放在一起运行时出现“Segmentation fault”错误。
注:xhprof是从github上下载的最新版。

遇到问题时的上下文:

1: 新建项目,使用phalcon命令行工具

phalcon create-project store

2:修改入口文件,加入xhprof支持

3:web访问出现502,无任何php级别的错误日志

在终端下执行:php index.php 提示“段错误"

4:使用pecl上的xhprof版本,问题更多:自动加载类的问题。

5:逐行调试代码,找到报错处代码:

new \Demo\Moduls();  //该行会调用phalcon的自动加载类来引入文件

问题分析:

使用phalcon引入文件的方式与xhprof冲突。

各种测试及结果:

1:去除xhprof, 页面正常

(php5.5.26 + phalcon正常)

2:更换php版本为5.5.22,页面正常

(php5.5.22 + phalcon + xhprof 正常)

3:在php5.5.26上执行简单输出,加入xhprof,页面正常

(php5.5.26 + xhprof 正常)

小结:3者同时使用时存在问题。

解决问题步骤:

# ulimit -c unlimited

//开启core dump

# php index.php

//重新运行代码,输出:段错误 (core dumped),同时生成core dump文件
# gdb php -c core.[\d]+

//使用gdb调试coredump文件

# bt

//显示错误堆栈

//根据错误提示,定位问题在xhprof.c文件的第971行。查看xhporf.c文件,输出错误代码的上下文变量值
# p data->prev_execute_data->opline
     //结果:value has been optimized out
     //根据提示知道,变量值被编译器优化掉了。为了看到变量值,重新编译xhprof

//下载xhprof源代码

# cd xhprof-dir/extension
# /usr/local/php/bin/phpize
# ./configure --with-php-config=/usr/local/php/bin/php-config
# vim Makefile
    //找到CFLAGS = -g -O2
    //改为CFLAGS = -g -O0
# make && make install

//为了可以调试phalcon,顺便重新编译了phalcon
   //下载phalcon源代码 
# cd cphalcon/

//phalcon提供了一个install文件,可直接执行进行安装。现在为了修改编译参数,需要修改install文件,vim install

1:将phpize替换为 /usr/local/php/bin/phpize (一共两处)
2:  修改最后一行,删除中间部分的 “make && make install ”,添加"--with-php-config=/usr/local/php/bin/php-config"
如:/usr/local/php/bin/phpize && ./configure --enable-phalcon --with-php-config=/usr/local/php/bin/php-config && echo -e "\n Please run Make "

# ./install
# cd 64bits/
# vim Makefile
    //搜索“CFLAGS=",改为“CFLAGS = -march=native -mtune=native -g -O0 -fomit-frame-pointer" 
# make && make install
    //此时,xhprof,phalcon都关闭了编译器优化,可以继续回到gdb调试

# php index.php
# gdb php -c core.[\d]+
# bt

//分析出错的的堆栈,发现从#0 - #4 ,一直在查找一个类文件,进入调试
# f 0
# p data->prev_execute_data->opline
    //输出结果0x0,此时问题已经找到,程序在调用一个空指针。修改xhprof.c加一个空指针判断。一切功能正常!

问题原因分析:

在php5.5中,对引入文件方式进行了调整,xhporf中也做了相关的判断。但通过phalcon引入文件时,未使用新的方式,造成xhprof分析代码时判断错误,造成了空指针调用。

时间: 2024-10-13 16:01:52

记一次PHP“Segmentation fault”调试经历的相关文章

Linux 下的段错误(Segmentation fault)调试方法

我们在用C/C++语言写程序的时侯,内存管理的绝大部分工作都是需要我们来做的.实际上,内存管理是一个比较繁琐的工作,无论你多高明,经验多丰富,难免会在此处犯些小错误,而通常这些错误又是那么的浅显而易于消除.但是手工“除虫”(debug),往往是效率低下且让人厌烦的,本文将就"段错误"这个内存访问越界的错误谈谈如何快速定位这些"段错误"的语句. 下面将就以下的一个存在段错误的程序介绍几种调试方法: 1 dummy_function (void) 2 { 3 unsig

linux Ubuntu(Segmentation fault)段错误出现原因及调试方法

  在linux下编译了一个程序,尝试运行的时候出现: Segmentation fault (core dumped) 初步确认为...完全不知道是什么玩意. 于是找度娘了. ---------------------------------------------------------------------------- 出现原因 原来这个东西叫做段错误,就程序运行的时候出现内存错误.有很多原因会导致这样的内存错误,但是应该把这些问题归结于程序的错误,那么程序是出现了什么样的错误了呢,为

eclipse+CDT调试segmentation fault错误

先来看两段代码-- 错误代码: #include "string.h" #include <stdlib.h> #include <stdio.h> void test(char ** dest, char * src, int n) { (*dest) = (char*) malloc(sizeof(char) * n); strcpy(*dest, src); } int main(int argc, char** args) { char ** p = N

Segmentation Fault的一种定位方法

1. 介绍 网上有很多Segmentation Fault的调试方法,下面这篇文件就很好 <Linux环境下段错误的产生原因及调试方法小结> 然而笔者在实际的使用中由于各种原因总觉得不够用 于是在网上找到了一种个人觉得更直接的方法 2. 原理 Segmentation Fault发生的时候,程序收到了信号11(SIGSEGV) 我们捕获该信号,然后利用事故发生时保存的寄存器现场加上栈信息定位到具体行 这里参考了< C/C++捕获段错误,打印出错的具体位置(精确到哪一行) > 使用其

结构体指针之 段错误 具体解释(segmentation fault)

一个网友问了我一个问题.一个C程序执行出现了段错误,这个问题非常好.非常多刚開始学习的人都easy犯这个错误,详细代码例如以下: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" > 这个编译没有问题,可是执行是段错误    Segmentation fault 由于你定义了一个结构体指针p.用来指向此类

Python调用C的SDK出现返回值不符合预期以及Segmentation fault

1.sdk返回值不是int型 1.1 登录函数调用 def login(ip, port, username, password, device_info, error_code):"""LLONG CLIENT_Login(char *pchDVRIP, WORD wDVRPort,char *pchUserName, char *pchPassword,LPNET_DEVICEINFO lpDeviceInfo, int *error = 0);:param ip::pa

ideviceinstaller报Segmentation fault: 11错误解决过程

背景:今天在另外一台电脑上安装appium,这台电脑是别人用过的,上面已经装了很多工具,遇到了ideviceinstaller报错的问题,搞了几乎一天,记录一下解决的过程. 由于ideviceinstaller是appium  1.4  ios自动化的必备工具,于是用brew install ideviceinstaller安装了ideviceinstaller,恶梦从此开始. 然后就是用appium跑ios脚本的时候提示ideviceinstaller错误,于是单独用ideviceinstal

再谈Segmentation fault (core dumped)问题 -查找段错误原因

再谈Segmentation fault (core dumped)问题 -查找段错误原因    在前一篇文章"Segmentation fault (core dumped) "有说了具体core dumped产生的原因. 下面主要来介绍下问题的解决与查找,在linux下一般都使用gdb进行调试,那今天我就以Ubuntu 14.04环境作为介绍 来查找正在的core dumped的原因.需要说明的是,你在编译程序的时候要加调试选项 -g. $ gcc -o app reverse.c

关于Segmentation fault错误

今天写程序时候出现了Segmentation fault,在网上查了一些资料,基本上的原因是,非法的内存访问. 例如数组的越界,在循环操作时循环变量的控制问题,也有字符串拷贝时长度溢出,指针指向了非法的空间,还有就是申明一个指针,但却没有对其初始化,就直接引用,或者没有开辟内存空间就释放内存,下面是自己找的一些可能情况,当做提醒自己吧. 1.内存访问越界 a) 由于使用错误的下标,导致数组访问越界. b) 搜索字符串时,依靠字符串结束符来判断字符串是否结束,但是字符串没有正常的使用结束符. c)