用Gdb+Nm调试Php C Extension程序
from:http://rdc.taobao.com/blog/cs/?p=1235最近在写Beanstalkd的php c extension客户端程序,写程序离不开调试,下面把调试中碰到的问题和解决方法和大家分享一下。
.so写好了是给php脚本调用的,如果php脚本执行崩掉了,.so也只能在进程中饮恨而终,这时候php脚本调试经常用的echo, print_r, var_dump都派不上用场了。即使能打印一点儿错误log出来,但也是只见表象,不知内情,根本解决不了一些诡异的bug。还好我们有gdb,下面就通过4步搞定php c extension的调试。
1.准备可调试的.so
在config.m4中加上下面的配置信息
http://rdc.taobao.com/blog/cs/wp-content/plugins/%E8%AE%BE%E7%BD%AEdebug%E4%BF%A1%E6%81%AF.png
./configure –enable-debug //和调试c程序的-g是一样的效果
make//生成带调试信息的.so
make install //安装.so到php解释器可以加载的路径
2.通过nm查看
要调试就要设置断点,要设置断点就要知道符号,php扩展中为了保证函数不和c库中的符号重复,在导出函数前都加上统一前缀zif,为了知道待调试.so都有哪些符号,nm命令再合适不过了。nm命令用来列出目标文件(.a或.so)的符号清单,包含函数或类名,如下图:
http://rdc.taobao.com/blog/cs/wp-content/plugins/nm%E7%AC%A6%E5%8F%B7%E4%BF%A1%E6%81%AF.png
3.加载php解释器和.so到gdb
是时候加载php解释器到gdb下了,这要用到gdb的file命令:file /usr/bin/php这里的php解释器不需要有调试符号,但要确保其加载了待调试的.so(可以通过php –m 命令参考)。
http://rdc.taobao.com/blog/cs/wp-content/plugins/%E6%A8%A1%E5%9D%97%E5%8A%A0%E8%BD%BD%E4%BF%A1%E6%81%AF.png
4.break设置断点,运行php脚本进行调试
都准备就绪了,设置断点吧,用从nm查看到的符号。设置好就run吧:run *.php这条命令是将.php脚本作为参数传递给php解释器,让php解释器执行*.php脚本,并在断点处停止。然后就list, print, next把bug都找出来吧。
http://rdc.taobao.com/blog/cs/wp-content/plugins/gdb%E6%AD%A5%E9%AA%A4.png
设置断点时一定要选择y,因为断点是设置在扩展so里面,必须load之后才能才能找到。
其他的就和调试c程序是一样的步骤了。祝大家调的开心^_^
页:
[1]