分析Linux 进程的方法有哪些?

  分析Linux 进程方法有哪些?ps查看进程id,看进程还在不在以及进程状态,在的话strace、psstack看下进程当前信息,是不是卡死在哪个位置,对比各帧最后调用信息找到异常点,如进程不在有corefile文件,直接上gdb查看corefile信息,其他疑难杂症怀疑进程状态信息的时候,看/proc/pid下面的进程状态信息。

 

分析Linux 进程的方法
  1、strace
  trace system calls and signals 跟踪进程内部的系统调用和信号
  什么是系统调用?系统调用,指运行在「用户态」的程序向操作系统「内核态」请求需要更高权限运行的服务,系统调用提供用户程序与操作系统之间的接口。
  strace后面跟着启动一个进程,可以跟踪启动后进程的系统调用和信号,这个命令可以看到进程执行时候都调用了哪些系统调用,通过指定不同的选项可以输出系统调用发生的时间,精度可以精确到微秒,甚至还可以统计分析系统「调用的耗时」,这在排查进程假死问题的时候很有用,能帮你发现进程卡在哪个系统调用上。已经在运行的进程也可以指定-p参数加pid像gdb attach那样附着上去跟踪。


  2、pstack
  print a stack trace of a running process 打印出运行中程序的堆栈信息。
  执行命令pstack pid 你能看到当前线程运行中的堆栈信息,其中的pid可用之前的ps命令获得,pstack可以看到进程内启动的线程号,每个进程内线程的「堆栈」内容也能看到。


  3、pstree
  display a tree of processes pstree按树形结构打印运行中进程结构信息,可以直观的查看进程和它启动的线程的关系,并能显示进程标识。


  4、gdb
  gdb是GNU开发的gcc套件中Linux下程序调试工具,你可以查看程序的堆栈、设置断点、打印程序运行时信息,甚至还能调试多线程程序,功能十分强大。在这里把gdb当成一个命令来讲有点大材小用。

  要用gdb调试C/C++程序首先编译的时候要加-g选项,g++ -g test.cpp -o test这样生成的程序就可以用gdb来调试啦。
  可以直接用gdb启动程序调试,命令:gdb prog
  用gdb附着到一个已经启动的进程上调试也可以。命令:gdb prog pid
  程序崩溃之后参数corefile也可以用gdb调试,看看程序死掉之前留了什么遗言(堆栈信息)给你。命令:gdb prog corefile,这里有一点需要注意,有些Linux
  系统默认程序崩溃不生成corefile,这时你需要ulimit -c unlimited这样就能生成corefile了。


本文链接:https://www.chenifan.cn/jishu/419.html

>>免责声明:本网站部分内容来源于互联网或用户投稿,内容版权归原作者所有,文章观点为原作者独立发表,不代表澈逆凡博客立场,不对其真实性、准确性负责!如本站内容侵犯了您的权益,我们也会在第一时间予以删除!
> 分析Linux 进程的方法有哪些?