zoukankan      html  css  js  c++  java
  • [zz]Linux调试工具strace和gdb常用命令小结

    strace(用来跟踪任何程序的系统调用)和 GDB 调试工具(用来在受控的环境中运行程序的功能齐全的调试工具)

    strace 专注于监控一个程序系统调用和它接受到的所有信号(与Unix系统上的truss是一样的),使用的是内核系统调用ptrace。另外,还有类似的ltrace(同样是基于ptrace的),它功能是能够跟踪进程的库函数调用。

    gdb比starce能做的事情更多,比如gdb可以获得堆栈跟踪信息,堆栈跟踪不仅会告诉你程序当前正在做什么,有底层的信息(如等待网络套接字),也有较高级别的信息(如正在执行什么类型的网络操作)。

    下面是使用过程中一些命令小结:

    strace调试工具

    strace工具用于跟踪进程执行时的系统调用和所接收的信号,包括参数、返回值、执行时间。在Linux中,用户程序要访问系统设备,必须由用户态切换到内核态,这是通过系统调用发起并完成的。

    strace常用参数:

    -c  统计每种系统调用执行的时间、调用次数、出错次数,程序退出时给出报告

    -p pid  跟踪指定的进程,可以使用多个-p同时跟踪多个进程

    -o filename  strace默认输出到stdout,-o可以将输出写入到指定的文件

    -f  跟踪由fork产生的子进程的系统调用

    -ff  常与-o选项一起使用,不同进程(子进程)产生的系统调用输出到各个filename.pid文件中

    -F  尝试跟踪vfork子进程系统调用,注意:与-f同时使用时, vfork不被跟踪

    -e expr  输出过滤表达式,可以过滤掉不想输出的strace结果

    -e trace=set  指定跟踪set中的系统调用

    -e trace=network  跟踪与网络有关的所有系统调用

    -e strace=signal  跟踪所有与系统信号有关的系统调用

    -e trace=ipc  跟踪所有与进程通讯有关的系统调用

    -e signal=set  指定跟踪set中的信号

    -e read=set  输出从指定文件中读出的数据,例如-e read=3,5

    -e write=set  输出写入到指定文件中的数据,例如-e write=1

    -r  打印每一个系统调用的相对时间

    -t  在输出中的每一行前加上时间信息

    -tt  在输出中的每一行前加上时间信息,时间精确到微秒级

    -ttt  在输出中的每一行前加上时间信息,输出为相对时间

    -s  指定每一行输出字符串的长度(默认为32)

    strace使用举例:

    strace -t whoami  #跟踪whoami可执行程序,每行输出结果前打印执行的时间

    strace -p 17151 -p 17152 -p 17153  #同时跟踪进程17151、17152、17153

    strace -f -e trace=read,write -p 17151 -o log  #跟踪进程17151及子进程read和write系统调用,输出到log文件

    gdb调试工具

    GDB是GNU开源组织发布的一个强大的UNIX下的程序调试工具。gcc编译时加上-g参数,可以使可执行程序加上gdb调试信息。

    (1)info

    简写:i,列出gdb子命令的信息,如info breakinfo variablesinfo stack等。

    (2)list [file:]function

    简写:l,查看当前行的上下文,默认为10行,也可以设置在某个函数处列出源码。

    (3)edit [file:]function

    简写:e,编辑当前所在的行,也可以编辑某个函数的源码。

    (4)break [file:]function

    简写:b,设置断点,可以设置在某行或某个函数处。

    (5)run [arglist]

    简写:r,运行程序至断点处停住,run命令之后可以加上调试程序需要的参数。

    (6)next

    简写:n,单条语句执行。

    (7)continue

    简写:c,继续运行程序至下一个断点。

    (8)print

    简写:p,打印变量的值。

    (9)bt

    查看函数堆栈信息。

    (10)enter

    回车键,重复上一次调试命令。

    (11)help [name]

    显示指定的gdb命令的帮助信息。

    (12)quit

    简写:q,退出gdb

  • 相关阅读:
    java API 文档
    java容器
    java学习笔记 java.io.File类
    理解性能的奥秘——应用程序中慢,SSMS中快(1)——简介
    第六章——根据执行计划优化性能(3)——键值查找
    第六章——根据执行计划优化性能(2)——查找表/索引扫描
    第六章——根据执行计划优化性能(1)——理解哈希、合并、嵌套循环连接策略
    SQL Server 执行计划操作符详解(3)——计算标量(Compute Scalar)
    SQL Server 执行计划操作符详解(2)——串联(Concatenation )
    SQL Server 执行计划操作符详解(1)——断言(Assert)
  • 原文地址:https://www.cnblogs.com/zhangzhang/p/2850355.html
Copyright © 2011-2022 走看看