原文网址:Linux命令--top--使用/教程/实例_IT利刃出鞘的博客-CSDN博客
简介
说明
本文用示例介绍Linux中top命令的用法。
top命令可以实时显示系统中各个进程的资源占用状况,包括:进程ID、CPU占用率、内存占用率 等。
示例
命令 |
作用 |
top -Hp PID |
显示一个进程中各个线程CPU的占用率 |
top -d 1 |
每1秒刷新一次 |
top -p 15273 |
只让 top 命令查看某个进程 |
top -b -n 1 > /root/top.log |
把 top 命令的执行结果重定向到文件中。 果在操作终端执行 top 命令,则并不能看到系统中所有的进程,默认看到的只是 CPU 占比靠前的进程。如果我们想要看到所有的进程,则可以把 top 命令的执行结果重定向到文件中。 |
选项
选项 |
含义 |
-b |
批处理模式输出。一般和"-n"选项合用,把输出重定向到文件中; |
-c |
显示整个命令行而不只是显示命令名 |
-d 秒数 |
指定 top 命令每隔几秒更新。默认是 3 秒; |
-i |
使top不显示任何闲置或者僵死进程。 |
-H |
线程模式(Threads-Mode)。只显示一个进程中的线程。 |
-n 次数 |
指定 top 命令执行的次数。一般和"-"选项合用; |
-p 进程PID |
仅查看指定 ID 的进程; |
-S |
指定累计模式 |
-s |
使 top 命令在安全模式中运行,避免在交互模式中出现错误; |
-u 用户名 |
只监听某个用户的进程; |
交互
在 top 命令的显示窗口中,还可以使用如下按键,进行交互操作:
- ? 或 h:显示交互模式的帮助;
- P:按照 CPU 的使用率排序,默认就是此选项;
- M:按照 内存的使用率排序;
- N:按照 PID 排序;
- T:按照 CPU 的累积运算时间排序,也就是按照 TIME+ 项排序;
- k:按照 PID 给予某个进程一个信号。一般用于中止某个进程,信号 9 是强制中止的信号;
- r:按照 PID 给某个进程重设优先级(Nice)值;
- q:退出 top 命令;
结果含义
[root@localhost ~]# top
top - 12:26:46 up 1 day, 13:32, 2 users, load average: 0.00, 0.00, 0.00
Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.1%us, 0.1%sy, 0.0%ni, 99.7%id, 0.1%wa, 0.0%hi, 0.1%si, 0.0%st
Mem: 625344k total, 571504k used, 53840k free, 65800k buffers
Swap: 524280k total, 0k used, 524280k free, 409280k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
19002 root 20 0 2656 1068 856 R 0.3 0.2 0:01.87 top
1 root 20 0 2872 1416 1200 S 0.0 0.2 0:02.55 init
2 root 20 0 0 0 0 S 0.0 0.0 0:00.03 kthreadd
3 root RT 0 0 0 0 S 0.0 0.0 0:00.00 migration/0
4 root 20 0 0 0 0 S 0.0 0.0 0:00.15 ksoftirqd/0
5 root RT 0 0 0 0 S 0.0 0.0 0:00.00 migration/0
6 root RT 0 0 0 0 S 0.0 0.0 0:10.01 watchdog/0
7 root 20 0 0 0 0 S 0.0 0.0 0:05.01 events/0
8 root 20 0 0 0 0 S 0.0 0.0 0:00.00 cgroup
9 root 20 0 0 0 0 S 0.0 0.0 0:00.00 khelper
10 root 20 0 0 0 0 S 0.0 0.0 0:00.00 netns
11 root 20 0 0 0 0 S 0.0 0.0 0:00.00 async/mgr
12 root 20 0 0 0 0 S 0.0 0.0 0:00.00 pm
13 root 20 0 0 0 0 S 0.0 0.0 0:01.70 sync_supers
14 root 20 0 0 0 0 S 0.0 0.0 0:00.63 bdi-default
15 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kintegrityd/0
16 root 20 0 0 0 0 S 0.0 0.0 0:02.52 kblockd/0
17 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kacpid
18 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kacpi_notify
命令的输出主要分为两部分:
- 第一部分是前五行,显示的是整个系统的资源使用状况,我们就是通过这些输出来判断服务器的资源使用状态的;
- 第二部分从第六行开始,显示的是系统中进程的信息;
前五行
- 第一行为任务队列信息,具体内容如表 1 所示。
表 1 任务队列信息
内容
说明
19:16:08
系统当前时间。
up 2 day, 10:34
系统的运行时间,本机已经运行2天10小时34分钟。
2 users
当前登录了两个用户。
load average: 0.12, 0.06, 0.06
系统在之前1分钟,5分钟,15分钟的平均负载。
如果CPU是单核,则这个数超过1,就是高负载。
如果CPU是四核,则这个数超过4,就是高负载。
(这个平均负载完全是个人经验来进行判断的,
一般认为不应该超过服务器CPU的核数。)
- 第二行为进程信息,具体内容如表 2 所示。
表 2 进程信息
内容
说明
Tasks: 112 total
系统中的进程总数。
1 running
正在运行的进程数。
111 sleeping
睡眠的进程。
0 stopped
正在停止的进程。
0 zombie
僵尸进程。如果不是0,需要手工检查僵尸进程。
- 第三行为 CPU 信息,具体内容如表 3 所示。
表 3 CPU信息
内容
说明
Cpu(s): 0.2%us
用户模式占用的CPU百分比。
0.2%sy
系统模式占用的CPU百分比。
0.0%ni
改变过优先级的用户进程占用的CPU百分比。
99.7%id
空闲CPU的CPU百分比。
0.0%wa
等待输入/输出的进程的占用CPU百分比。
0.0%hi
硬中断请求服务占用的CPU百分比。
0.0%si
软中断请求服务占用的CPU百分比。
0.0%st
st(Steal time)虚拟时间百分比。就是当有虚拟机时,虚拟CPU等待实际CPU的时间百分比。
- 第四行为物理内存信息,具体内容如表 4 所示。
表 4 物理内存信息
内容
说明
Mem: 1906280k total
物理内存的总量,单位KB。
467692k used
已经使用的物理内存数量。
1438588k free
空闲的物理内存数量,我们使用的是虚拟机,总共只分配了2GB内存,所以只有1438MB左右的空闲内存了。
59528k buffers
作为缓冲的内存数量。
- 第五行为交换分区(swap)信息,如表 5 所示。
表 5 交换分区信息
内容
说明
Swap: 511996k total
交换分区(虚拟内存)的总大小。
0k used
已经使用的交互分区的大小。
511996k free
空闲交换分区的大小。
232692k cached
作为缓存的交互分区的大小。
第六行之后
列名称 |
含义 |
PID |
当前运行进程的ID |
USER |
该进程所属的用户 |
PR |
优先级,数值越小优先级越高 |
NI |
(nice)优先级,数值越小、优先级越高。反映一个进程“优先级”状态的值,其取值范围是-20至19, 共40个级别。这个值越小,表示进程”优先级”越高,而值越 大“优先级”越低。一般会把nice值叫做静态优先级 。 |
VIRT |
进程占用的虚拟内存 ,单位为 KB |
RES |
进程占用的物理内存 ,单位为 KB。 |
SHR |
共享内存大小,单位为 KB。 |
S |
进程的状态。S表示休眠,R表示正在运行,Z表示僵死状态,N表示 该进程优先值为负数 |
%CPU |
进程占用CPU的百分比 |
%MEM |
进程使用的物理内存和总内存的百分比 |
TIME+ |
该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值。 |
COMMAND |
进程的命令名 |