linux之Top命令

进程相关概念

平均负载的定义
平均负载是指单位时间内,系统处于【可运行状态】和【不可中断状态】的平均进程数,也就是平均活跃进程数
可运行状态的进程:是指正在使用CPU或者等待CPU的进程
不可中断状态的进程:正处于内核态关键流程中的进程,并且这些流程是不可被中断,也就是在ps命令中看到的D状态(低状态)

当平均负载为12的时候,意味着什么

在12个CPU的机器上,意味着所有的CPU刚好被使用
在24个CPU的机器上,意味着有一半的CPU刚好被使用
在6个CPU的机器上,意味着有一半的进程(线程)竞争不到CPU

导致平均负载升高的场景
CPU 密集型应用
I/O 密集型应用(尤其是D状态的进程)

当平均负载高于 CPU 数量 70% 的时候,就应该分析排查负载高的问题。一旦负载过高,就可能导致进程响应变慢,进而影响服务的正常功能
平均负载与 CPU 使用率关系
CPU 密集型进程,使用大量 CPU 会导致平均负载升高,此时这两者是一致的
I/O 密集型进程,等待 I/O 也会导致平均负载升高,但 CPU 使用率不一定很高
大量等待 CPU 的进程调度也会导致平均负载升高,此时的 CPU 使用率也会比较高

kill -9 pid 杀掉相关的进程,
kill -9 不能杀掉的进程 ,D 状态进程,zombie 僵尸进程

CPU 上下文切换

进程上下文切换:

进程的运行空间可以分为内核空间和用户空间,当代码发生系统调用时(访问受限制的资源),CPU 会发生上下文切换,系统调用结束时,CPU 则再从内核空间换回用户空间。一次系统调用,两次 CPU 上下文 切换
系统平时会按一定的策略调用进程,会导致进程上下文切换
进程在阻塞等到访问资源时,也会发生上下文切换
进程通过睡眠函数挂起,会发生上下文切换
当有优先级更高的进程运行时,为了保证高优先级进程的运行,当前进程会被挂起
线程上下文切换:

同一进程里的线程,它们共享相同的虚拟内存和全局变量资源,线程上下文切换时,这些资源不变
线程自己的私有数据,比如栈和寄存器等,需要在上下文切换时保存切换

中断上下文切换

为了快速响应硬件的事件,中断处理会打断进程的正常调度和执行,转而调用中断处理程序,响应设备事件

系统性能查看其他命令

原文链接:https://blog.csdn.net/uuqaz/article/details/124972418

Top命令系统介绍文章

http://c.biancheng.net/view/1065.html
在这里插入图片描述

命令格式

top [参数]

命令功能
显示当前系统正在执行的进程的相关信息,包括进程ID、内存占用率、CPU占用率等

命令参数
-b 批处理
-c 显示完整的路径
-I 忽略失效过程
-s 保密模式
-S 累积模式
-i<时间> 设置间隔时间
-u<用户名> 指定用户名
-p<进程号> 指定进程
-n<次数> 循环显示的次数
显示进程信息

> top

top - 21:16:05 up 59 days,  4:13,  1 user,  load average: 0.25, 0.42, 0.42
Tasks: 181 total,   1 running, 180 sleeping,   0 stopped,   0 zombie
%Cpu(s):  2.3 us,  3.1 sy,  0.0 ni, 94.6 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem : 16265536 total,   807520 free, 12503980 used,  2954036 buff/cache
KiB Swap:        0 total,        0 free,        0 used.  2625804 avail Mem 

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                                                        
29160 root       0 -20 4343004 399576   3936 S  49.5  2.5  10752:33 vpnserver                                                      
 

前五行是当前系统情况整体的统计信息区。下面我们看每一行信息的具体意义。

第一行,任务队列信息,同 uptime 命令的执行结果,具体参数说明情况如下

top - 21:16:05 up 59 days,  4:13,  1 user,  load average: 0.25, 0.42, 0.42

21:16:05 当前系统时间
up 59 days距离上次服务器重启服务器已经运行了59天
1 user当前有1个用户登录系统
load average: 0.25, 0.42, 0.42 load average后面的三个数分别是1分钟、5分钟、15分钟的负载情况
load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

第二行,Tasks — 任务(进程),具体信息说明如下

Tasks: 181 total,   1 running, 180 sleeping,   0 stopped,   0 zombie

系统现在共有181个进程,其中处于运行中的有1个,180个在休眠(sleep),stoped状态的有0个,zombie状态(僵尸)的有0个。

第三行,cpu状态信息,具体属性说明如下

%Cpu(s):  2.3 us,  3.1 sy,  0.0 ni, 94.6 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st

2.3% us — 用户空间占用CPU的百分比。
3.1% sy — 内核空间占用CPU的百分比。
0.0% ni — 改变过优先级的进程占用CPU的百分比
94.6% id — 空闲CPU百分比
0.0% wa — IO等待占用CPU的百分比
0.0% hi — 硬中断(Hardware IRQ)占用CPU的百分比
0.2% si — 软中断(Software Interrupts)占用CPU的百分比
0.0% st - 表示被强制等待虚拟CPU的时间
第四行,内存状态,具体信息如下

KiB Mem : 16265536 total,   807520 free, 12503980 used,  2954036 buff/cache

16265536k total — 物理内存总量(16GB)
807520k free — 空闲内存总量(807MB)
12503980k used — 使用中的内存总量(12GB)
2954036k buffers — 缓存的内存量 (2GB)
第五行,swap交换分区信息,具体信息说明如下

KiB Swap:        0 total,        0 free,        0 used.  2625804 avail Mem 

0k total — 交换区总量(0)
0k free — 空闲交换区总量(0)
0k used — 使用的交换区总量(0)
2625804 avail Mem 虚拟内存总量(2.6GB)
buff/cache虽然占用物理内存,但当内存不够时也可以直接使用,因此物理内存的可使用空间为:free + buff/cache。

第六行,空行。
第七行以下:各进程(任务)的状态监控,项目列信息说明如下
PID — 进程id
USER — 进程所有者
PR — 进程优先级
NI — nice值。负值表示高优先级,正值表示低优先级
VIRT — 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
RES — 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
SHR — 共享内存大小,单位kb
S —进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程
%CPU — 上次更新到现在的CPU时间占用百分比
%MEM — 进程使用的物理内存百分比
TIME+ — 进程使用的CPU时间总计,单位1/100秒
COMMAND — 进程名称(命令名/命令行)

多U多核CPU监控

在top基本视图中,按键盘数字“1”,可监控每个逻辑CPU的状况:

在这里插入图片描述

高亮显示当前运行进程

敲击键盘“b”(打开/关闭加亮效果),top的视图变化如下
在这里插入图片描述

进程id为22221的“top”进程被加亮了,top进程就是视图第二行显示的唯一的运行态(runing)的那个进程,可以通过敲击“y”键关闭或打开运行态进程的加亮效果。

进程字段排序

top默认的排序列是%CPU
敲击键盘“x”(打开/关闭排序列的加亮效果),top的视图变化如下

在这里插入图片描述
通过shift + >或shift + <可以向右或左改变排序列
在这里插入图片描述

按一下shift + >就会按照%MEM排序,以此类推

显示完整命令

top -c或者先输入top进入后按c键

top -c

在这里插入图片描述
设置信息更新次数

top -n 2

表示更新两次后终止更新显示

设置信息更新周期

top -d 3
表示更新周期为3秒

显示指定的进程信息

top -p 123

top交互命令

在top 命令执行过程中可以使用的一些交互命令。这些命令都是单字母的,如果在命令行中使用了s 选项, 其中一些命令可能会被屏蔽。

h 显示帮助画面,给出一些简短的命令总结说明
k 终止一个进程。
i 忽略闲置和僵死进程。这是一个开关式命令。
q 退出程序
r 重新安排一个进程的优先级别
S 切换到累计模式
s 改变两次刷新之间的延迟时间(单位为s),如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s
f或者F 从当前显示中添加或者删除项目
o或者O 改变显示项目的顺序
l 切换显示平均负载和启动时间信息
m 切换显示内存信息
t 切换显示进程和CPU状态信息
c 切换显示命令名称和完整命令行
M 根据驻留内存大小进行排序
P 根据CPU使用百分比大小进行排序
T 根据时间/累计时间进行排序
W 将当前设置写入~/.toprc文件中
按q可以退出top
————————————————
版权声明:本文为CSDN博主「入门小站」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_37335761/article/details/122793401

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值