码迷,mamicode.com
首页 > 数据库 > 详细

gdb 分析出错

时间:2015-09-09 13:28:51      阅读:264      评论:0      收藏:0      [点我收藏+]

标签:

1 创建测试代码test.php

<?php
function test1(){
        while(true){
              sleep(1);
        }
}
echo getmypid() "\r\n"; test1();
?>

2 运行文件  php test.php 获取到pid 

3 运行 gdb -p pid

4 进入gdb交互

(gdb) print (char *)executor_globals.active_op_array->filename
$1 = 0x9853a34 "/home/test.php"
(gdb) print (char *)executor_globals.active_op_array->function_name
$2 = 0x9854db8 "test1"
(gdb) print executor_globals->current_execute_data->opline->lineno
$3 = 4

也可以使用.gdbinit文件。这个文件在php源码的根目录下。使用方法如下

(gdb) source /data/software/php-5.5.25/.gdbinit 
(gdb) zbacktrace
[0xa453f34] sleep(1) /home/xinhailong/test/php/test.php:4 
[0xa453ed0] test1() /home/xinhailong/test/php/test.php:8 
(gdb) 

 

补充:

使用gcore 收集信息

$gcore pid(进程号)   生成core.1234 文件

$gdb core.1234  查看信息

 

gdb 分析出错

标签:

原文地址:http://www.cnblogs.com/wangxusummer/p/4794078.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!