Linux - top命令监控列表的详细解析

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: Linux - top命令监控列表的详细解析

学习top命令


可看此博文:https://www.cnblogs.com/poloyy/p/12551943.html

 

统计信息区(系统资源信息区)


前五行,即列表上方的五行

image.png


第一行:输出系统任务队列信息


  • 18:46:38:系统当前时间
  • up 2days 1:54:系统开机后到现在的总运行时间
  • 1 user:当前登录用户数
  • load average: 0, 0.01, 0.05:系统负载,系统运行队列的平均利用率,可认为是可运行进程的平均数;三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值;单核CPU中load average的值=1时表示满负荷状态,多核CPU中满负载的load average值为1*CPU核数

 

第二行:任务进程信息


image.png

  • total:系统全部进程的数量
  • running:运行状态的进程数量
  • sleeping:睡眠状态的进程数量
  • stoped:停止状态的进程数量
  • zombie:僵尸进程数量

 

第三行:CPU信息


  • us用户空间占用CPU百分比
  • sy内核空间占用CPU百分比
  • ni:已调整优先级的用户进程的CPU百分比
  • id空闲CPU百分比,越低说明CPU使用率越高
  • wa:等待IO完成的CPU百分比
  • hi:处理硬件中断的占用CPU百分比
  • si:处理软中断占用CPU百分比
  • st:虚拟机占用CPU百分比

 

第四行:物理内存信息


image.png

以下内存单位均为MB

  • total:物理内存总量
  • free:空闲内存总量
  • used:使用中内存总量
  • buff/cacge:用于内核缓存的内存量

 

第五行:交换区内存信息


image.png

  • total:交换区总量
  • free:空闲交换区总量
  • used:使用的交换区总量
  • avail Mem:可用交换区总量

注:如果used不断在变化, 说明内核在不断进行内存和swap的数据交换,说明内存真的不够用了

 

问题:内存空间还剩多少空闲呢?

答案:空闲内存=空闲内存总量+缓冲内存量 +可用交换区总量

 

进程信息区(进程列表)


image.png

  • PID:进程号
  • USER:运行进程的用户
  • PR:优先级
  • NI:nice值。负值表示高优先级,正值表示低优先级
  • VIRT:进程虚拟内存的大小,只要是进程申请过的内存,即便还没有真正分配物理内存,也会计算在内;VIRT=SWAP+RES
  • RES:进程实际使用的物理内存大小,不包括 Swap 和共享内存
  • SHR:共享内存大小,比如与其他进程共同使用的共享内存、加载的动态链接库以及程序的代码段等
  • S:进程状态
  • %CPU:CPU 使用率
  • %MEM:进程使用武力内存占系统总内存的百分比
  • TIME+:上次启动后至今的总运行时间
  • COMMAND:命令名or命令行

 

内存的重点

  • 虚拟内存通常并不会全部分配给物理内存,从上面的输出可以发现每个进程的虚拟内存都比物理内存大得多
  • 共享内存 SHR 并不一定是共享的,比如程序的代码段、非共享的动态链接库
  • SHR 也包括了进程间真正共享的内容,所以在计算多个进程的内存使用时,不要把所有进程的 SHR 直接相加得出结果

 

%CPU

  • 表示进程的 CPU 使用率
  • 是用户态和内核态 CPU 使用率的总和(us+sy)
  • 包括进程用户空间使用的 CPU、通过系统调用执行的内核空间 CPU、在就绪队列等待运行的 CPU
  • 在虚拟环境中, 它还包括了运行虚拟机占用的 CPU
  • 没有细分进程的用户态 CPU 和内核态 CPU

 

进程状态

  • R=运行状态
  • S=睡眠状态
  • D=不可中断的睡眠状态
  • T=跟踪/停止
  • Z=僵尸进程
相关文章
|
7天前
|
Linux Shell
Linux 10 个“who”命令示例
Linux 10 个“who”命令示例
33 14
Linux 10 个“who”命令示例
|
16天前
|
Linux 数据库
Linux中第一次使用locate命令报错?????
在Linux CentOS7系统中,使用`locate`命令时出现“command not found”错误,原因是缺少`mlocate`包。解决方法是通过`yum install mlocate -y`或`apt-get install mlocate`安装该包,并执行`updatedb`更新数据库以解决后续的“can not stat”错误。
30 9
|
14天前
|
缓存 并行计算 Linux
深入解析Linux操作系统的内核优化策略
本文旨在探讨Linux操作系统内核的优化策略,包括内核参数调整、内存管理、CPU调度以及文件系统性能提升等方面。通过对这些关键领域的分析,我们可以理解如何有效地提高Linux系统的性能和稳定性,从而为用户提供更加流畅和高效的计算体验。
26 2
|
14天前
|
监控 网络协议 Linux
Linux netstat 命令详解
Linux netstat 命令详解
|
20天前
|
运维 监控 网络协议
运维工程师日常工作中最常用的20个Linux命令,涵盖文件操作、目录管理、权限设置、系统监控等方面
本文介绍了运维工程师日常工作中最常用的20个Linux命令,涵盖文件操作、目录管理、权限设置、系统监控等方面,旨在帮助读者提高工作效率。从基本的文件查看与编辑,到高级的网络配置与安全管理,这些命令是运维工作中的必备工具。
64 3
|
23天前
|
Linux
在 Linux 系统中,`find` 命令
在 Linux 系统中,`find` 命令
25 1
|
监控 网络协议 Linux
Linux监控工具简单整合
Linux监控工具简单整合
127 0
|
运维 监控 网络协议
4个好用的Linux监控工具
本文介绍了作者常用的 4 个 Linux 监控工具,希望可以帮助读者提高生产力。
|
监控 网络协议 Unix
80 多个 Linux 必备的监控工具
第一章   新春巨献: 80 多个 Linux 系统管理员必备的监控工具  随着互联网行业的不断发展,各种监控工具多得不可胜数。这里列出网上最全的监控工具。
1751 0