摘自:linux--进程理解_e我所欲也的博客-CSDN博客_linux进程理解
操作系统概念与定位
操作系统:是管理计算机硬件与软件资源的计算机程序(或者说是软件),同时也是计算机系统的内核与基石。操作系统需要处理如管理与配置内存、决定系统资源供需的优先次序、控制输入设备与输出设备、操作网络与管理文件系统等基本事务.
如何管理:管理=描述+组织
描述起来,用struct结构体
组织起来,用链表或其他高效的数据结构
总结操作系统的理解与定位
1.硬件交互,管理所有的软硬件资源
2.为用户程序(应用程序)提供一个良好的执行环境
3.在整个计算机软硬件架构中,操作系统的定位是:一款纯正的“搞管理”的软件
操作系统主要包括以下几个方面的功能 :
1.进程管理,其工作主要是进程调度,在单用户单任务的情况下,处理器仅为一个用户的一个任务所独占, 进程管理的工作十分简单。但在多道程序或多用户的情况 下,组织多个作业或任务时,就要解决处理器的调度、 分配和回收等问题 。
2.存储管理分为几种功能:存储分配、存储共享、存储保护 、存储扩张。
3.设备管理分有以下功能:设备分配、设备传输控制 、设备独立性。
4.文件管理:文件存储空间的管理、目录管理 、文件操作管理、文件保护。
5.作业管理是负责处理用户提交的任何要求。
————————————————
版权声明:本文为CSDN博主「e我所欲也」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_44785014/article/details/104782506
原文:https://blog.csdn.net/xingjia001/article/details/84304523
top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,常用于服务端性能分析。
统计信息:前五行是系统整体的统计信息;
进程信息:统计信息下方类似表格区域显示的是各个进程的详细信息,默认5秒刷新一次。
统计信息说明:
第1行:Top 任务队列信息(系统运行状态及平均负载),与uptime命令结果相同。
第1段:系统当前时间,例如:16:07:37
第2段:系统运行时间,未重启的时间,时间越长系统越稳定。 格式:up xx days, HH:MM。例如:5 days, 17:54, 表示连续运行了5天17小时54分钟
第3段:当前登录用户数,例如:1 user,表示当前只有1个用户登录
第4段:系统负载,即任务队列的平均长度,3个数值分别统计最近1,5,15分钟的系统平均负载
系统平均负载:单核CPU情况下,0.00 表示没有任何负荷,1.00表示刚好满负荷,超过1侧表示超负荷,理想值是0.7;
多核CPU负载:CPU核数 * 理想值0.7 = 理想负荷,例如:4核CPU负载不超过2.8何表示没有出现高负载。
第2行:Tasks 进程相关信息
第1段:进程总数,例如:Tasks: 121 total,表示总共运行121个进程
第2段:正在运行的进程数,例如:1 running,表示正在运行1个进程
第3段:睡眠的进程数,例如:120 sleeping,表示120个睡眠进程
第4段:停止的进程数,例如:0 stopped,表示0个stop进程
第5段:僵尸进程数,例如:0 zombie,表示0个僵尸进程
第3行:Cpus CPU相关信息,如果是多核CPU,按数字1可显示各核CPU信息,此时1行将转为Cpu核数行,数字1可以来回切换。
第1段:us 用户空间占用CPU百分比,例如:Cpu(s): 0.3% us
第2段:sy 内核空间占用CPU百分比,例如:0.3% sy
第3段:ni 用户进程空间内改变过优先级的进程占用CPU百分比,例如:0.0%ni,
第4段:id 空闲CPU百分比,例如:99.3 %id
第5段:wa 等待输入输出的CPU时间百分比,例如:0.0%wa
第6段:hi CPU服务于硬件中断所耗费的时间总额,例如:0.0%hi
第7段:si CPU服务软中断所耗费的时间总额,例如:0.0%si
第8段:st Steal time 虚拟机被hypervisor偷去的CPU时间(如果当前处于一个hypervisor下的vm,实际上hypervisor也是要消耗一部分CPU处理时间的)
第4行:Mem 内存相关信息
第1段:物理内存总量,例如:Mem:1882736 total
第2段:使用的物理内存总量,例如:82100 used
第3段:空闲内存总量,例如:Mem:1013200 free
第4段:用作内核缓存的内存量,例如:787436 buffers
第5行:Swap 交换分区相关信息
第1段:交换区总量,例如:Swap: 524284 total
第2段:使用的交换区总量,例如:0 used
第3段:空闲交换区总量,例如:524284 free
第4段:缓冲的交换区总量,190468 cached
进程信息:
在top命令中按f按可以查看显示的列信息,按对应字母来开启/关闭列,大写字母表示开启,小写字母表示关闭。带*号的是默认列。
A: PID = (Process Id) 进程Id;
E: USER = (User Name) 进程所有者的用户名;
H: PR = (Priority) 优先级
I: NI = (Nice value) nice值。负值表示高优先级,正值表示低优先级
O: VIRT = (Virtual Image (kb)) 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
Q: RES = (Resident size (kb)) 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
T: SHR = (Shared Mem size (kb)) 共享内存大小,单位kb
W: S = (Process Status) 进程状态。D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程
K: %CPU = (CPU usage) 上次更新到现在的CPU时间占用百分比
N: %MEM = (Memory usage (RES)) 进程使用的物理内存百分比
M: TIME+ = (CPU Time, hundredths) 进程使用的CPU时间总计,单位1/100秒
b: PPID = (Parent Process Pid) 父进程Id
c: RUSER = (Real user name)
d: UID = (User Id) 进程所有者的用户id
f: GROUP = (Group Name) 进程所有者的组名
g: TTY = (Controlling Tty) 启动进程的终端名。不是从终端启动的进程则显示为 ?
j: P = (Last used cpu (SMP)) 最后使用的CPU,仅在多CPU环境下有意义
p: SWAP = (Swapped size (kb)) 进程使用的虚拟内存中,被换出的大小,单位kb
l: TIME = (CPU Time) 进程使用的CPU时间总计,单位秒
r: CODE = (Code size (kb)) 可执行代码占用的物理内存大小,单位kb
s: DATA = (Data+Stack size (kb)) 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
u: nFLT = (Page Fault count) 页面错误次数
v: nDRT = (Dirty Pages count) 最后一次写入到现在,被修改过的页面数
y: WCHAN = (Sleeping in Function) 若该进程在睡眠,则显示睡眠中的系统函数名
z: Flags = (Task Flags
X: COMMAND = (Command name/line) 命令名/命令行
top命令选项
-b:以批处理模式操作;
-c:显示完整的治命令;
-d:屏幕刷新间隔时间;
-I:忽略失效过程;
-s:保密模式;
-S:累积模式;
-i<时间>:设置间隔时间;
-u<用户名>:指定用户名;
-p<进程号>:指定进程;
-n<次数>:循环显示的次数。
top命令交互
常用交互操作
基础操作
1:显示CPU详细信息,每核显示一行
d / s :修改刷新频率,单位为秒
h:可显示帮助界面
n:指定进程列表显示行数,默认为满屏行数
q:退出top
面板隐藏显示
l:隐藏/显示第1行负载信息;
t:隐藏/显示第2~3行CPU信息;
m:隐藏/显示第4~5行内存信息;
进程列表排序
M:根据驻留内存大小进行排序;
P:根据CPU使用百分比大小进行排序;
T:根据时间/累计时间进行排序;
————————————————
版权声明:本文为CSDN博主「星空黑夜」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/xingjia001/article/details/84304523
四、什么样的Load值得警惕(单核)?
Load < 0.7时:系统很闲,马路上没什么车,要考虑多部署一些服务
0.7 < Load < 1时:系统状态不错,马路可以轻松应对
Load == 1时:系统马上要处理不多来了,赶紧找一下原因
Load > 5时:马路已经非常繁忙了,进入马路的每辆汽车都要无法很快的运行
五、三个Load值要先看哪一个?
结合具体情况具体分析:
1)1分钟Load>5,5分钟Load<1,15分钟Load<1:短期内繁忙,中长期空闲,初步判断是一个“抖动”,或者是“拥塞前兆”
2)1分钟Load>5,5分钟Load>1,15分钟Load<1:短期内繁忙,中期内紧张,很可能是一个“拥塞的开始”
3)1分钟Load>5,5分钟Load>5,15分钟Load>5:短中长期都繁忙,系统“正在拥塞”
4)1分钟Load<1,5分钟Load>1,15分钟Load>5:短期内空闲,中长期繁忙,不用紧张,系统“拥塞正在好转”
1.5 高速缓存至关重要
系统花费了大量的时间把信息从一个地方挪到另一个地方。
1.6 存储设备形成层次结构(第六章详细讲解)
寄存器层次结构的主要思想:上一层的存储器作为低一层存储器的高速缓存。
1.7 操作系统管理硬件
两个基本功能:
(1)防止硬件被失控的应用程序滥用
(2)向应用程序提供简单一致的机制来控制复杂而又通常大不相同的低级硬件设备。
操作系统通过几个基本的抽象概念(进程、虚拟内存和文件)来实现这两个功能。
文件:IO设备的抽象;
虚拟内存:主存和磁盘IO设备的抽象;
进程:处理器-主存-IO设备的抽象
1.7.3 虚拟内存
在linux中,地址空间最上面的区域是保留给操作系统中的代码和数据的。
注意:内核虚拟内存的地址是最大的,用户代码不可见的。
1.7.4 文件
IO设备的抽象,每个IO设备,包括磁盘、键盘、显示器、甚至网络,都可以看成是文件。
文件就是字节序列,仅此而已。
系统中的所有输入输出都是通过使用以小组成为Unix I/O的系统函数调用读写文件来实现的。
1.8 系统之间利用网络通信
从一个单独的系统来看,网络可视为一个IO设备。
1.9 重要主题
1.9.1 Amdahl定律
1.9.2 并发和并行
参考读书笔记:https://blog.csdn.net/a2888409/article/details/47294893
超级干货:3个性能监控和优化命令详解