当前位置:首页 > 公众号精选 > 架构师社区
[导读]来自:后端技术学堂 操作系统「进程」是学计算机都要接触的基本概念,抛开那些纯理论的操作系统底层实现,在Linux下做软件开发这么多年,每次程序运行出现问题,都要一步一步分析进程各种状态,去排查问题出在哪里,这次lemon带你在Linux环境下实操,一步步探

资深程序员总结:分析Linux进程的6个方法,我全都告诉你

来自:后端技术学堂

操作系统「进程」是学计算机都要接触的基本概念,抛开那些纯理论的操作系统底层实现,在Linux下做软件开发这么多年,每次程序运行出现问题,都要一步一步分析进程各种状态,去排查问题出在哪里,这次lemon带你在Linux环境下实操,一步步探究揭开「Linux进程」的那些秘密。

何为进程

首先我们说下「程序」的概念,程序是一些保存在磁盘上的指令的有序集合,是静态的。进程是程序执行的过程,包括了动态创建、调度和消亡的整个过程,它是程序资源管理的最小单位。

线程是操作操作系统能够进行运算调度的最小单位。大部分情况下,它被包含在进程之中,是进程中的实际运作单位,一个进程内可以包含多个线程,是资源调度的最小单位。[引用维基百科]

资深程序员总结:分析Linux进程的6个方法,我全都告诉你
多线程程序模型

探究进程第一步,你在吗?还好吗?

ps

report a snapshot of the current processes. 列出当前系统进程的快照。

找到进程PID ( Process IDentity ),pid唯一标识一个进程。用ps这个命令,这个命令大家应该都知道吧,对于小白用户,首先他不是Photoshop。

资深程序员总结:分析Linux进程的6个方法,我全都告诉你
Ps

给大家简单介绍一下,一般用法是ps -ef列出系统内经常信息,通常都会带管道grep出自己感兴趣的进程,像这样ps -ef|grep intresting第一列PID代表进程号,PPID(parent process ID)代表父进程号。资深程序员总结:分析Linux进程的6个方法,我全都告诉你

探究进程第二步,让我看看你都交了哪些朋友(系统调用 & 信号)

strace

trace system calls and signals   跟踪进程内部的系统调用和信号

什么是「系统调用」?系统调用(system call),指运行在「用户态」的程序向操作系统「内核态」请求需要更高权限运行的服务,系统调用提供用户程序与操作系统之间的接口。

strace后面跟着启动一个进程,可以跟踪启动后进程的系统调用和信号,这个命令可以看到进程执行时候都调用了哪些系统调用,通过指定不同的选项可以输出系统调用发生的时间,精度可以精确到微秒,甚至还可以统计分析系统「调用的耗时」,这在排查进程假死问题的时候很有用,能帮你发现进程卡在哪个系统调用上。已经在运行的进程也可以指定-p参数加pidgdb attach那样附着上去跟踪。资深程序员总结:分析Linux进程的6个方法,我全都告诉你

资深程序员总结:分析Linux进程的6个方法,我全都告诉你
strace统计

探究进程第三步,让我看看你带的小弟们(线程)。

pstack

print a stack trace of a running process 打印出运行中程序的堆栈信息。

执行命令pstack pid 你能看到当前线程运行中的堆栈信息,其中的pid可用之前的ps命令获得,pstack可以看到进程内启动的线程号,每个进程内线程的「堆栈」内容也能看到。资深程序员总结:分析Linux进程的6个方法,我全都告诉你

看到上面打印出的LWP了吗,这里是个知识点, LPW是指Light-weight process 轻量级线程。引申知识:

  1. Linux中没有真正的线程
  2. Linux中没有的线程 Thread是由进程来模拟实现的所以称作:轻量级进程
  3. 进程是「资源管理」的最小单元,线程是「资源调度」的最小单元(这里不考虑协程)

探究进程第四步,让小弟们(线程)出来排个队吧。

pstree

display a tree of processes pstree按树形结构打印运行中进程结构信息

可以直观的查看进程和它启动的线程的关系,并能显示进程标识。

资深程序员总结:分析Linux进程的6个方法,我全都告诉你
pstree

探究进程第五步,是死(进程崩溃)是活(进程运行中)我都要知道你的秘密(堆栈帧 & 上下文)。

gdb

gdb是GNU开发的gcc套件中Linux下程序调试工具,你可以查看程序的堆栈、设置断点、打印程序运行时信息,甚至还能调试多线程程序,功能十分强大。

在这里把gdb当成一个命令来讲有点大材小用,要详细说gdb的话,完全可以撑起一篇文章的篇幅,这里长话短说,有机会再开一篇文章详细介绍下它。

使用

要用gdb调试C/C++程序首先编译的时候要加-g选项,g++ -g test.cpp -o test这样生成的程序就可以用gdb来调试啦。

  1. 可以直接用gdb启动程序调试,命令: gdb prog
  2. 用gdb附着到一个已经启动的进程上调试也可以。命令: gdb prog pid
  3. 程序崩溃之后参数corefile也可以用gdb调试,看看程序死掉之前留了什么遗言(堆栈信息)给你。命令: gdb prog corefile,这里有一点需要注意,有些Linux系统默认程序崩溃不生成 corefile,这时你需要 ulimit -c unlimited这样就能生成 corefile了。 资深程序员总结:分析Linux进程的6个方法,我全都告诉你

探究进程第六步,关于你的所有,我都想知道。

更近一步

通过/proc/pid文件了解进程的运行时信息和统计信息。/proc系统是一个伪文件系统,它只存在内存当中,而不占用外存空间,以文件系统的方式为内核与进程提供通信的接口。进入系统/proc目录:

资深程序员总结:分析Linux进程的6个方法,我全都告诉你
proc目录

/proc目录下有很多以数字命名的目录,每个数字代表进程号PID它们是进程目录。系统中当前运行的每一个进程在/proc下都对应一个以进程号为目录名的目录/proc/pid,它们是读取进程信息的接口,我们可以进到这个文件里面,了解进程的运行时信息和统计信息。

高频使用

/proc/pid目录下的有一些重要文件,挑几个使用频率高的讲一讲。/proc/pid/environ 包含了进程的可用环境变量的列表 。程序出问题了如果不确定环境变量是否设置生效,可以cat这个文件出来查看确认一下。

/proc/pid/fd/ 这个目录包含了进程打开的每一个文件的链接。从这里可以查看进程打开的文件描述符信息,包括标准输入、输出、错误流,进程打开的socket连接文件描述符也能看到,lsof命令也有类似的作用。

/proc/pid/stat包含了进程的所有状态信息,进程号、父进程号、 线程组号、 该任务在用户态运行的时间 、 该任务在用内核态运行的时间、 虚拟地址空间的代码段、 阻塞信号的位图等等信息应有尽有。

其他统计

/proc/pid/cmdline 该文件保存了进程的完整命令行
/proc/pid/cwd一个符号连接, 指向进程当前的工作目录
/proc/pid/exe包含了正在进程中运行的程序链接
/proc/pid/mem包含了进程在内存中的内容
/proc/pid/statm包含了进程的内存使用信息

总结一下

好了,一顿操作下来,你对进程和它背后的秘密你已经非常了解了,下次我们的好朋友「进程」如果遇到了什么问题(崩溃coredump、假死、阻塞、系统调用超时、文件描述符异常),你应该知道如何帮它处理了吧!我们来总结一下:

  • ps查看进程id,看看进程还在不在以及进程状态
  • 如果在的话 stracepsstack看下进程当前信息,是不是卡死在哪个位置,对比各帧最后调用信息找到异常点
  • 如果进程不再了,如果有 corefile文件,直接上 gdb查看 corefile信息
  • 其他疑难杂症怀疑进程状态信息的时候,看看 /proc/pid下面的进程状态信息,可能会给你启发。
  • 最后,如果以上都不行,闭目祈祷吧!

  • 资深程序员总结:分析Linux进程的6个方法,我全都告诉你

写在最后

今天的分享希望对你有帮助,祝大家写的服务永不宕机,从不coredump,让上面教你的操作吃灰去吧。资深程序员总结:分析Linux进程的6个方法,我全都告诉你

                        图片来源网络|侵删

最后,感谢各位的阅读。文章的目的是分享对知识的理解,技术类文章我都会反复求证以求最大程度保证准确性,若文中出现明显纰漏也欢迎指出,我们一起在探讨中学习。

reference

https://man.linuxde.net/gdb

https://blog.csdn.net/dan15188387481/article/details/49450491

https://blog.csdn.net/m0_37925202/article/details/78759408

https://blog.csdn.net/enweitech/article/details/53391567

特别推荐一个分享架构+算法的优质内容,还没关注的小伙伴,可以长按关注一下:

资深程序员总结:分析Linux进程的6个方法,我全都告诉你

长按订阅更多精彩▼

资深程序员总结:分析Linux进程的6个方法,我全都告诉你

如有收获,点个在看,诚挚感谢

免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭