当前位置:首页 > 技术学院 > 技术前线
[导读]线程是操作操作系统能够进行运算调度的最小单位。大部分情况下,它被包含在进程之中,是进程中的实际运作单位,一个进程内可以包含多个线程,是资源调度的最小单位。

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

何为进程

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

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

一:理论知识

1:在了解linux进程之前,我们先来了解了解shell脚本在执行命令的过程,

shell也是一个程序,它与其他程

序最大的不同是:它的目的是执行其他程序,而不是从事计算,绘图,存储等等具体事务。分析一下shell的工作原理有助于破除shell的神秘感,更好的

掌握shell命令。以ls -l *.c 为例

1、shell不断询问是否有键盘输入,用户以enter结束键盘输入后,shell程序以空格为分隔符,得到"ls","-l","*.c",三个字符串。

2、

shell发现第三个字符串包含"*"通配符,就会在当前路径(或指定路径)下搜索满足这个通配符的文件。有bar.c和foo.c两个文件,然后展开成

{"ls","-l","bar.c","foo.c"}四个字符串,并保存在argv这个二维字符数组中,并赋值argc为4。

3、

shell然后搜索PATH这个全局变量保存的路径,寻找一个叫"ls"的命令。如果存在,则fork()一个子进程,调用exec()加载运行ls命

令。ls的main(int argc, string ** argv)函数的参数就是从shell那里得来的。若不存在就会提示用户"command

not found"。

4、ls程序执行后,会分析argc和argv,"-l"表示这是一个选项开关,表明用户想得到文件的详细信息,并把这个开关量保存,以便最后输出的时候选择信息的格式。

5、ls执行完既定的步骤后,退出并返回退出码,若成功则返回0,否则根据错误的不同返回不同的非零数字。

6、shell在得到成功退出码后,继续等待用户输入

如上:命令在执行过程中,

命令-->二进制文件--->运行---->作相应的加载--->得出结论 在此过程中,所记录的东西会产生进程;

2.进程:系统没有干完的活 即cpu未完成的工作,正在运行的程序 类型:程序进程/服务进程(eg:apache)常驻在内存中 一个程序运行时至少产生一个进程

在内核看来,进程是一个个实体,内核必须在它们之间共享各种计算机资源。对于像内存这样的受限资源来说,内核一开始会为进程分配一定数量的资源,并在进程的生命周期内,统筹该进程和整个系统对资源的需求,对这一分配进行调整。程序终止时,内核会释放所有此类资源,供其他进程重新使用。其他资源(如

CPU、网络带宽等)等属于可再生资源,但必须在所有进程间平等共享。

3.进程管理的作用:

判断服务器的健康状态

查看系统中的所有进程

杀死进程

4:进程的内存布局

逻辑上将一个进程划分为以下几个部分(也称为段)

文本 :程序的指令。

数据 :程序使用的静态变量。

堆 :程序可从该区域动态分配额外内存。

栈 :随机数调用、返回而增减的一片内存,用于为局部变量和函数调用链接信息分配存储空间。

5:创建进程和执行程序

进程可使用系统调用fork()来创建一个新进程。调用fork()的进程被称为父进程,新创建的进程则被称为子进程。内核通过对父进程的复制来创

建子进程。子进程从父进程处继承数据段、栈段以及堆段的副本后,可以修改这些内容,不会影响父进程的“原版”内容。(在内存中被标记为只读的程序文本段则

由父、子进程共享)

然后,子进程要么去执行与父进程共享代码中的另一组不同函数,或者,更为常见的情况是使用系统调用execve()去加载并执行一个全新程序。execve()会销毁现有的文本段、数据段、栈段及堆段,并根据新程序的代码,创建新段来替换它们。

6:进程ID和父进程ID

每一进程都有一个唯一的整数型进程标识符(PID).此外,每一进程还具有一个父进程标识符(PPID)属性,用以标识请求内核创建自己的进程。

7:进程终止和终止状态

可使用以下两种方式之一来终止一个进程:其一,进程可使用_exit(

)系统调用(或相关的exit()库函数),请求退出;其二,向进程传递信号,将其"杀死”。无论以何种方式退出,进程都会生成“终止状态”,一个非负小

整数,可供父进程的wait()系统调用检测。在调用_exit()的情况下,进程会指明自己的终止状态。若由信号来“杀死”进程,则会根据导致进程“死

亡”的信号类型来设置进程的终止状态。(有时会将传递进_exit()的参数称为进程的“退出状态”,以示与终止状态有所不同,后者要第指传递给

_exit()的参数值,要么表示“杀死”进程的信号。)

根据 惯例,终止状态为0表示进程“功成身退”,非0则表示有错误发生。大多数shell会将前一执行程序的终止状态保存于shell变量$?中。

二:进程的状态

1:system Monitor(命令打开:)中状态:status:1:sleeping(要使用时可以被唤醒)

2:running

3:stop(不可以自动唤醒 可以手动唤醒,cpu可以将此处所使用的信息传递给进程)

2.状态切换:系统回收cpu上缓存信息资源/使用某些程序

3.系统资源:硬盘 cpu 内存

cpu一级缓存(直接可以用)

二级缓存

内存(需要去取)如果内存中资源被回收,则进程关闭

4:ps 默认查看所处shell处产生的进程

三:进程所涉及的一些命令

####1.ps命令####ps

a ##关于当前环境的所有进程

x ##与当前环境无关的所有进程

f ##显示进程从属关系

e ##显示进程调用环境工具的详细信息

l ##长列表显示进程的详细信息

u ##显示进程的用户信息

加-和不加-的区别:

ps aux #查看系统中所有进程,使用BSD操作系统格式

ps -le # 查看系统中所有进程 ,使用linux操作格式

ps aux

USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND

user:该进程由哪个用户产生

pid:进程的id号

%cpu:该进程占用cpu资源的百分比

%mem:该进程占有物理内存百分比

VSZ:该进程占用虚拟内存的大小

RSS:该进程占用实际内存的大小

tty:该进程在哪个终端进行tty1-tty7代表本地控制台,pts/0-255代表虚拟终端

状态:

R:运行

S:睡眠

T:停止状态

s:包含子进程

+:位于后台

ps ax -o %cpu,%mem,user,group,comm,nice,pid ##指定显示进程的某些信息

%cpu ##显示进程cpu负载

%mem ##显示进程内存负载

user ##进程用户

group ##进程组

comm ##进程名称

nice ##进程优先级

pid ##进程的id

ps ax -o %cpu,comm --sort ##按照进程信息排序

+ ##正序

- ##倒序

%cpu ##cpu负载排序

%mem ##内存负载

####2.环境中进程的前后台调用####

jobs ##查看被打入环境后台的进程

ctrl+z ##把占用终端的进程打入后台

fg ##把后台进程调回前台

bg ##把后台暂停的进程运行

comm & ##让命令直接在后台运行

###7.top命令####

top ##监控系统负载工具

top 和 ps 区别

##ps看到的是命令执行瞬间的进程信息,top可以持续的监视

##ps只是查看进程,而top还可以监控系统性能,如平均负载,cpu,内存

##top可以直接操作进程,如改变优先级(命令r)和关闭进程(命令k)

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

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 信息技术
关闭