调试zSeries上的Linux应用程序类似于调试其他体系结构上的Linux应用程序。对于有经验的Linux开发人员,最大的挑战是理解新的系统体系结构。对于刚接触Linux的大型机开发人员,掌握新的调试工具似乎是一项令人畏惧的任务。不要害怕。本文将提供一些有用的提示来帮助您入门。 学问来自实践,但是对于调试工具,在没有出现问题而迫使您去修复它们之前,“实践”是不会发生的。考虑到这点,下面将提供让您入门的“速成”指南。
User Debug 日志记录 调试一个崩溃的程序的第一步是弄清哪里出了错。zSeries 上的Linux内核具有这样一个内置特性,它在用户进程崩溃时记录一些基本的调试信息。要启用这个特性,请以 root 用户身份执行如下命令:
| echo 1 >> /proc/sys/kernel/userprocess_debug |
当某个进程崩溃时,日志文件(/var/log/messages)中就会给出附加的信息,包括程序终止原因、故障地址,以及包含程序状态字(PSW)、通用寄存器和访问寄存器的简要寄存器转储。
| Mar 31 11:34:28 l02 kernel: User process fault: interruption code 0x10Mar 31 11:34:28 l02 kernel: failing address: 0Mar 31 11:34:28 l02 kernel: CPU:1Mar 31 11:34:28 l02 kernel: Process simple (pid: 30122, stackpage=05889000)Mar 31 11:34:28 l02 kernel:Mar 31 11:34:28 l02 kernel: User PSW:070dc000 c00ab738Mar 31 11:34:28 l02 kernel: task: 05888000 ksp: 05889f08 pt_regs: 05889f68Mar 31 11:34:28 l02 kernel: User GPRS:Mar 31 11:34:28 l02 kernel: 00000000004019a0004019a000000000Mar 31 11:34:28 l02 kernel: 00000003c00ab732004008f800400338Mar 31 11:34:28 l02 kernel: 40018ffc0040061c40018e347ffff800Mar 31 11:34:28 l02 kernel: 00400434804006248040066e7ffff800Mar 31 11:34:28 l02 kernel: User ACRS:Mar 31 11:34:28 l02 kernel: 00000000000000000000000000000000Mar 31 11:34:28 l02 kernel: 00000001000000000000000000000000Mar 31 11:34:28 l02 kernel: 00000000000000000000000000000000Mar 31 11:34:28 l02 kernel: 00000000000000000000000000000000Mar 31 11:34:28 l02 kernel: User Code:Mar 31 11:34:28 l02 kernel: 44 40 50 00 07 fe a7 4a 00 01 18 54 18 43 18 35a8 24 00 00 |
图 1图 1 表明程序(名为“simple”)以一个程序中断代码 0x10 终止(操作系统原理表明这是一个段转换错误),而故障地址为 0。毫无疑问,有人使用了空指针。现在我们知道发生了什么,下面需要弄清它发生在何处。
| 【内容导航】 |
| 第1页:教你如何驯服Linux系统中的Bug | 第2页:教你如何驯服Linux系统中的Bug |
| 第3页:教你如何驯服Linux系统中的Bug | |
教你自己动手制作软盘上的Linux引导器Linux常用指令大全学习相关资讯 本文评论 查看全部评论 (0)