[转] 查看CPU使用率 top命令详解

本文详细解析了Linux系统中top命令的功能与使用方法,包括实时监控CPU状态、内存使用情况及进程管理。介绍了top命令的参数设置、交互命令及如何自定义显示内容。
部署运行你感兴趣的模型镜像

一 top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前 台,直到用户终止该程序为止. 比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用.内存使用和执行时间 对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定.



说明:前五行都统计系统整体信息的 下面是进程信息区

1 第一行: 跟uptime 一样,分别是当前时间13:48 系统运行时间3 days 当前登录用户数1user 系统负载load average:,即任务队列的平均长度

2 第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行
Tasks: 96 total 进程总数
1 running 正在运行的进程数 
95 sleeping 睡眠的进程数
0 stopped 停止的进程数
0 zombie 僵尸进程数

Cpu(s): 0.0% us 用户空间占用CPU百分比 查看CPU使用率
1.0% sy 内核空间占用CPU百分比 
0.0% ni 用户进程空间内改变过优先级的进程占用CPU百分比 
100.0% id 空闲CPU百分比
0.0% wa 等待输入输出的CPU时间百分比 
0.0% hi
0.0% si
0.0% st

3 最后两行为内存信息
Mem:506708k total 物理内存总量
477080k used 使用的物理内存总量
29628k free 空闲内存总量
113736k buffers 用作内核缓存的内存量
Swap: 1015800k total 交换区总量
112 used 使用的交换区总量
1015688k free 空闲交换区总量
169384k cached 缓冲的交换区总量
内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,
该数值即为这些内容已存在于内存中的交换区的大小。
相应的内存再次被换出时可不必再对交换区写入。

4 进程信息区 
PID 进程ID PPID 父进程ID 
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 命令名/命令行 
二 以上只是默认情况下仅显示比较重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通过下面的快捷键来更改显示内容。
1 通过f键可以选择显示的内容。按 f 键之后会显示列的列表,按 a-z 即可显示或隐藏对应的列,最后按回车键确定

 

2 按o键可以改变列的显示顺序。按小写的 a-z 可以将相应的列向右移动,而大写的 A-Z 可以将相应的列向左移动。最后按回车键确定。

 

3 按大写的FO键,然后按 a-z 可以将进程按照相应的列进行排序。而大写的R键可以将当前的排序倒转。

4 使用参数:
d 指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。
p 通过指定监控进程ID来仅仅监控某个进程的状态。
q 该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。
S 指定累计模式
s 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。
i 使top不显示任何闲置或者僵死进程。
c 显示整个命令行而不只是显示命令名
5 top 使用时的交互命令:
Ctrl+L擦除并且重写屏幕。
 h或者?显示帮助画面,给出一些简短的命令总结说明。
  k 终止一个进程。系统将提示用户输入需要终止的进程PID,以及需要发送给该进程什么样的信号。一般的终止进程可以使用15信号;如果不能正常结束那就使用信号9强制结束该进程。默认值是信号15。在安全模式中此命令被屏蔽。
  i忽略闲置和僵死进程。这是一个开关式命令。
  q退出程序。
  r重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。
  S切换到累计模式。
  s改变两次刷新之间的延迟时间。系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s。需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加。
  f或者F从当前显示中添加或者删除项目。
  o或者O改变显示项目的顺序。
  l切换显示平均负载和启动时间信息。
  m切换显示内存信息。
  t切换显示进程和CPU状态信息。
  c切换显示命令名称和完整命令行。
  M根据驻留内存大小进行排序。
  P根据CPU使用百分比大小进行排序。
  T根据时间/累计时间进行排序。
W将当前设置写入~/.toprc文件中。这是写top配置文件的推荐方法

您可能感兴趣的与本文相关的镜像

LobeChat

LobeChat

AI应用

LobeChat 是一个开源、高性能的聊天机器人框架。支持语音合成、多模态和可扩展插件系统。支持一键式免费部署私人ChatGPT/LLM 网络应用程序。

<think> 我们正在讨论如何查看CPU使用率命令,根据用户提供的引用[1]和之前的对话历史,用户已经知道了一些基础命令(如top、vmstat、sar),但需要更聚焦于CPU使用率的监测。 结合引用[1]的内容: - top命令可以实时显示CPU使用率,包括用户空间、系统空间、等待IO等详细分解。 - vmstat也可以查看CPU使用情况,但引用中没有给出具体用法。 - sar命令可以周期性采集CPU使用率,并可以指定显示某个CPU核心。 另外,在之前的回答中,我们提到了mpstat(属于sysstat包,和sar同属一个包),它也是用来查看CPU使用率的。 因此,我们需要整理一个关于查看CPU使用率命令的详细回答,包括实时监控和周期性监控。 注意:用户要求生成相关问题,并且回答中引用的段落末尾自然地添加引用标识。 我们按照以下结构组织: 1. 实时监控命令top, htop, mpstat) 2. 周期性/历史监控(sar) 3. 其他常用命令(vmstat) 4. 使用场景建议 5. 相关问题 注意:用户提到“引用[1]”的内容,我们在回答中需要引用时使用[^1](因为用户给的引用标记是[^1])。 另外,根据用户要求,所有数学表达式用$...$,独立公式用$$...$$,但我们这个回答中可能没有数学公式,所以可以忽略。 我们开始: </think> 以下是根据您的需求整理的 **Linux系统查看CPU使用率命令详解**,结合系统监控场景和性能分析实践: --- ### 一、实时监控命令 #### 1. **`top`** - 动态全览(推荐首选) ```bash top ``` - **核心指标解析**(第三行CPU状态): ```text %Cpu(s): 12.5 us, 6.2 sy, 0.0 ni, 80.1 id, 0.4 wa, 0.0 hi, 0.7 si, 0.0 st ``` - **`us`**:用户空间程序CPU使用率(未调优优先级) - **`sy`**:内核空间CPU使用率 - **`id`**:空闲CPU百分比 - **`wa`**:等待I/O操作的CPU时间 - **`st`**:虚拟机占用CPU时间(虚拟化环境)[^1] #### 2. **`htop`** - 增强版top(需安装) ```bash sudo apt install htop && htop # Debian/Ubuntu ``` - 优势:颜色标记负载、树状进程视图、鼠标交互操作 --- ### 二、周期采样命令 #### 3. **`vmstat`** - 系统资源综合报告 ```bash vmstat 1 5 # 每秒采样1次,共5次 ``` - **CPU关键列**: ```text r b swpd free buff cache si so bi bo in cs us sy id wa st 2 0 0 280000 45200 980000 0 0 50 30 120 350 15 8 77 0 0 ``` - **`us`** + **`sy`** = 总CPU使用率 - **`r`**:等待运行的进程数(直接反映CPU过载) #### 4. **`sar`** - 历史数据分析(需安装`sysstat`) ```bash sar -u 1 5 # 每秒采集CPU使用率,共5次 ``` ```text Linux 5.15... (host) 06/01/2023 _x86_64_ (16 CPU) 12:00:01 CPU %user %nice %system %iowait %steal %idle 12:00:02 all 18.02 0.00 5.31 0.25 0.00 76.42 ``` - 参数扩展: ```bash sar -P ALL 1 3 # 查看每个逻辑核心的详细使用率 sar -q 1 5 # 监控进程队列和负载状态[^1] ``` --- ### 三、核心指标解析 | 指标 | 含义 | 警戒阈值 | 问题关联 | |------|-----------------------|----------|------------------------| | `us` | 用户程序CPU消耗 | >70% | 应用代码性能问题 | | `sy` | 内核操作CPU消耗 | >30% | 系统调用/驱动异常 | | `wa` | I/O等待占比 | >20% | 存储性能瓶颈 | | `id` | CPU空闲率 | <10% | 资源饱和 | | `r` | 运行队列长度 | >CPU核数 | CPU资源不足 | --- ### 四、使用场景建议 - **快速诊断卡顿** → `top`(实时定位高负载进程) - **性能基线分析** → `sar -u`(配合`cron`定时采集) - **I/O瓶颈排查** → `vmstat` + `iostat`(交叉验证`wa`值) - **多核负载均衡** → `sar -P ALL`(检查核心利用率分布) > 示例:检测CPU过载问题 > ```bash > vmstat 1 | awk '{if($13<10 && NR>2) print "警告:CPU空闲率低于10%!"}' > ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值