gdb 调试入门,大牛写的高质量指南

  gdb 调试入门,大牛写的高质量指南python

  2016/11/23 · 开发 · 1 评论 · Brendan Gregg, GDB, 调试shell

  分享到:11Canvas 绘制时钟创业公司的Nodejs工程师PHP环境LAMP/LNMP安装与配置轻松学会Laravel-基础篇本文由 伯乐在线 - 道法子 翻译,艾凌风 校稿。未经许可,禁止转载!工具

  英文出处:Brendan Gregg。欢迎加入翻译组。性能

  没想到Brendan Gregg这样的大牛,会写出这样一篇gdb tutorials文章:gdb Debugging Full Example (Tutorial): ncurses 。但可能正如文章开头所说,大牛对网上的gdb文章都不太满意,因此才有了这篇高质量指南,gdb入门者的福音。—— 何登成测试

  若是你是系统管理员,但还不认识 Brendan Gregg,那网上流传甚广的 3 张 Linux 性能工具图(连接),你应该看过的。—— 伯小乐。url

  ( Brendan Gregg).net

  gdb 调试 ncurses 全过程:翻译

  发现网上的“gdb 示例”只有命令而没有对应的输出,我有点不满意。gdb 是 GNU 调试器,Linux 上的标配调试器。当我看 Greg Law 在 CppCon 2015 上的演讲《给我 15 分钟,我将改变你的对 GDB 的认知》的时候,我想起了示例输出的不足,幸运的是,此次有输出!这 15 分钟太值了。调试

  它也启发我去分享一个完整的 gdb 调试实例,包含输出和每一个步骤,甚至钻牛角尖的状况。这不是一个特别有趣或奇怪的问题,只是常规的 gdb 调试会话。但它包含了基础的东西能够勉强做为教程使用,记住 gdb 里还有不少东西我这里没用到。教程

  我会以 root 权限运行下面的命令,由于我在调试一个工具,它须要 root 权限(目前)。须要的时候可用 sudo 获取 root 权限。你也不必通读全篇︰ 我已列出每一步,你能够浏览它们找感兴趣的看。

  1. 问题概述

  更多阅读请点击:河南治疗牛皮癣医院

  更多阅读请点击:郑州牛皮癣

  BPF 工具箱里的 bcc 工具集有一个对cachetop.py 的 pull 请求,它经过程序使用 top-like display 显示 page cache 的统计。太好了 !然而,当我测试它时,遇到了段错误︰

  1

  2# ./cachetop.py

  Segmentation fault

  注意它说的是“段错误”,不是“段错误(核心已转储)”。我想要一个核心转储文件用来调试。(核心转储文件是进程内存的拷贝 – 这个名字来源于磁芯存储器时代 – 可用调试器分析)

  分析核心转储文件是一种方法,但不是调试这个问题的惟一方法。我能够在 gdb 中运行此程序,来检查这个问题。我也能够在段错误发生时,用外部追踪器去抓数据和栈帧。咱们从核心转储文件入手。

  2. 解决核心转储问题

  我检查一下核心转储的设置:

  1

  2

  3

  4# ulimit -c

  0

  # cat /proc/sys/kernel/core_pattern

  core

  ulimit -c 显示核心转储文件大小的最大值,这里是零:禁止核心转储(对于本进程和它的子进程)。

  /proc/…/core_pattern 仅仅被设为 “core”,表示会在当前目录下生成一个文件名为 “core” 的 核心转储文件。目前这样就好了,可是我要演示如何把它设置为全局位置。

  1

  2

  3# ulimit -c unlimited

  # mkdir /var/cores

  # echo "/var/cores/core.%e.%p" > /proc/sys/kernel/core_pattern

  你能够进一步定制 core_pattern;例如,%h 为主机名,%t 为转储的时间。这些选项被写在 Linux 内核源码 Documentation/sysctl/kernel.txt中。

  要使 core_pattern 保持不变,重启以后仍然有效,你能够经过设置 /etc/sysctl.conf 里的 “kernel.core_pattern” 实现。

  再来一次:

  1

  2

  3

  4

  5

  6

  7# ./cachetop.py

  Segmentation fault (core dumped)

  # ls -lh /var/cores

  total 19M

  -rw------- 1 root root 20M Aug 7 22:15 core.python.30520

  # file /var/cores/core.python.30520

  /var/cores/core.python.30520: ELF 64-bit LSB core file x86-64, version 1 (SYSV), SVR4-style, from 'python ./cachetop.py'

  好多了:咱们有了本身的核心转储文件。

  3. 启动 GDB

  如今我要用 gdb 启动目标程序(用 shell 替换符,”`”,不过在你肯定能用的状况下,也可指定完整路径),和核心转储文件:

相关文章
相关标签/搜索