linuxtop命令

编程

 

top 命令主要用于查看进程的相关信息,同时它也会提供系统平均负载,cpu 信息和内存信息。下面的截图展示了 top 命令默认提供的信息:

系统平均负载

top 命令输出中的第一行是系统的平均负载,这和 uptime 命令的输出是一样的:

13:05:49      表示系统当前时间。
up 7 days    表示系统最后一次启动后总的运行时间。
1 user          表示当前系统中只有一个登录用户。
load average: 0.01, 0.04, 0.00      表示系统的平均负载,最后的三个数字分别表示最后一分钟的系统平均负载,最后五分钟的系统平均负载,最后十五分钟的系统平均负载。

任务信息汇总

在 linux 系统中,一般把进程和线程统称为任务。第二行信息是对当前系统中所有任务的统计:

Tasks:270 total    表示当前系统的进程总数。
1 running             表示当前系统中有 1 个正在运行的进程。
269 sleeping        表示当前系统中有 269 个休眠的进程。
0 stopped            表示停止状态的进程数为 0。
0 zombie              表示处于僵死状态的进程数为 0。

CPU 信息

第三行显示 CPU 的使用情况:

这里一共有八个字段,是我们了解 CPU 负载的主要依据,下面我们逐一介绍。

us
进程在用户地址空间中消耗 CPU 时间的百分比。像 shell程序、各种语言的编译器、数据库应用、web 服务器和各种桌面应用都算是运行在用户地址空间的进程。这些程序如果不是处于 idle 状态,那么绝大多数的 CPU 时间都是运行在用户态。

sy
进程在内核地址空间中消耗 CPU 时间的百分比。所有进程要使用的系统资源都是由 Linux 内核处理的。当处于用户态(用户地址空间)的进程需要使用系统的资源时,比如需要分配一些内存、或是执行 IO 操作、再或者是去创建一个子进程,此时就会进入内核态(内核地址空间)运行。事实上,决定进程在下一时刻是否会被运行的进程调度程序就运行在内核态。对于操作系统的设计来说,消耗在内核态的时间应该是越少越好。在实践中有一类典型的情况会使 sy 变大,那就是大量的 IO 操作,因此在调查 IO 相关的问题时需要着重关注它。

ni
ni 是 nice 的缩写,可以通过 nice 值调整进程用户态的优先级。这里显示的 ni 表示调整过 nice 值的进程消耗掉的 CPU 时间。如果系统中没有进程被调整过 nice 值,那么 ni 就显示为 0。

id
CPU 处于 idle 状态的百分比。一般情况下, us + ni + id 应该接近 100%。

wa
CPU 等待磁盘 IO 操作的时间。和 CPU 的处理速度相比,磁盘 IO 操作是非常慢的。有很多这样的操作,比如:CPU 在启动一个磁盘读写操作后,需要等待磁盘读写操作的结果。在磁盘读写操作完成前,CPU 只能处于空闲状态。Linux 系统在计算系统平均负载时会把 CPU 等待 IO 操作的时间也计算进去,所以在我们看到系统平均负载过高时,可以通过 wa 来判断系统的性能瓶颈是不是过多的 IO 操作造成的。

hi & si
这两个值表示系统处理中断消耗的时间。中断分为硬中断和软中断,hi 表示处理硬中断消耗的时间,si 表示处理软中断消耗的时间。硬中断是硬盘、网卡等硬件设备发送给 CPU 的中断消息,当 CPU 收到中断消息后需要进行适当的处理(消耗 CPU 时间)。软中断是由程序发出的中断,最终也会执行相应的处理程序(消耗 CPU 时间)。

st
只有 Linux 在作为虚拟机运行时 st 才是有意义的。它表示虚机等待 CPU 资源的时间(虚机分到的是虚拟 CPU,当需要真实的 CPU 时,可能真实的 CPU 正在运行其它虚机的任务,所以需要等待)。

小写字母 t 可以控制是否显示任务信息汇总和 CPU 信息。没错,它能控制是否显示两行信息。

内存信息

内存信息包含两行内容,内存和交换空间:

top 命令中这部分的输出和 free 命令的输出基本相同,笔者在《linux free 命令》一文已经详细介绍过,这里不再赘述。

控制显示单位
top 命令默认以 K 为单位显示内存大小,这让人十分抓狂。好在我们可以通过大写字母 E 来切换内存信息区域的显示单位(注意,E 不能控制任务区域中的内存单位),下图以 GB 显示内存大小:

小写字母 m 可以控制是否显示内存信息。

任务详情

内存信息下面是一个空行(其实是与用户交互的区域),空行的下面就是任务详情区域:

默认情况下这里会显示 12 列数据,都是我们比较关心的进行相关的信息,下面我们一个一个的介绍。
PID     表示进程 ID。
USER  表示进程所有者的有效用户名称。简单说就是以哪个用户权限启动的进程。比如上图中有两个进程是用户 nick 启动的,还有一个是用户 prometheus 启动的,其它都是 root 用户启动的。
PR      表示进程执行的优先级,PR 的值是以 Linux 内核的视角看到的进程执行的优先级。
NI       从用户视角看到的进程执行优先级。注意上图中 NI 值为 -20 的两个进程,它们的 PR 值都是  0。
VIRT   表示进程使用的虚拟内存大小。
RES    表示进程使用的物理内存大小。
SHR   表示进程使用的共享内存的大小。
S        表示进程当前的状态。S 值有下面几种:
    D 不可中断的睡眠状态(uninterruptible sleep)
    I   idle 状态
    R 进程在 running 队列中,正在运行或准备运行(running)
    S 睡眠状态(sleeping)
    T 停止状态(stopped by job control signal)
    t  跟踪状态(stopped by debugger during trace)
    Z 僵尸状态(zombie)
%CPU     表示进程使用 CPU 的百分比。
%MEM   表示进程使用内存的百分比。
TIME+    表示进程累计使用的 CPU 时间。
COMMAND    表示运行进程对应的程序。

一般情况下这些信息足够了,但是如果你还想要更多的信息,你可以尝试添加更多的列。按下小写字母 f 可以进入任务信息的配置界面:

在这里你可以选择要显示的列,并且可以配置以哪一列进行排序。

显示内存大小的单位问题在任务详情区域也同样存在,默认的单位也是 KB。要改变它的单位需要使用小写字母 e 来进行切换,比如我可以把它切换为以 MB 为单位:

这样看起来就直观多了!

top 是一个非常复杂的命令,上面介绍的内容仅仅是一些皮毛而已。即便如此,你也可以用它来干不少的事情了!如果你想了解更多详细的信息,请参考 top 的使用手册。我们接下来介绍一些常见的用例。

显示多个 CPU 核心的详细信息

无论系统中有多少个 CPU 核心,默认的 CPU 信息总是输出一行,即所有核心加起来的综合数据。能不能查看各个 CPU 核心单独的数据呢?答案是,可以的。按键盘上的数字 1 就可以在不同的视图之间切换了:

以某列对进程排序

按小写字母 f 进入排序设置界面,选择某一列,按小写 "s" 指定排序,然后退出。
奇怪的是默认主界面上并看不出是以哪列排序的!可以使用小写字母 x 来粗体显示当前排序的列

可以看到 %CPU 列的字体加粗了吗?虽然不太明显,但勉强可以看到了。在使用 x 以粗体显示排序的列后,还可以使用 b 来高亮显示排序的列(注意,b 是配合 x 使用的):


还有一些预定义的命令可以直接完成以某列排序的功能,比如大写字母 M 以 %MEM 列排序;大写字母 N 以 PID 列排序;大写字母 P 以 %CPU 列排序;大写字母 T 以 TIME+ 列排序。
M        %MEM                     
N         PID                           
P         %CPU                        
T         TIME+

反转排序的结果是常见的需求,大写字母 R 可以将当期排序的结果反转。

显示进程执行的完整命令

默认 COMMAND 列只显示程序的名字,并不包含程序的路径。有时能够看到程序的完整路径是很方便的。你可以通过小写字母 c 来切换 COMMAND 列的显示模式:

不仅是程序的完整路径,连启动程序的参数都显示出来了!

隐藏 idle 的进程

在我们调查问题时,总希望以最快的方式找到繁忙的进程。但是 top 命令会把所有的进程列出,这就需要我们通过昏花的老眼去扫描一行行的进程信息。还好,我们可以借助小写字母 i 来控制是否显示处于 idle 状态的进程!使用这个命令后你会发现世界好清爽啊!

只显示某个用户的进程

如果你想查看以某个用户权限启动的进程,可以使用小写字母 u 。这会提示你输入用户的名称,在你输入用户名称后,按回车键:

上图中笔者输入的用户名为 nick,按回车键后就会过滤出所有以用户 nick 权限启动的进程。

过滤进程列表

可以根据进程名称、CPU 或 内存使用情况等指标过滤进程列表。当然,也可以同时应用多个过滤条件。常用的几个快捷键为:
o            -> 提示用户输入过滤条件
enter     -> 应用过滤条件
ctrl + o  -> 显示当前的过滤条件
=           -> 清除所有的过滤条件

按下字母 o 后,top 命令提示用户输入过滤过滤条件:

此时我们可以输入过滤条件并按回车键,比如输入下面的命令:

COMMAND=top

过滤的结果是进程列表中只显示 top 进程的信息。注意,这里的 COMMAND 要大写。
还可以过滤 CPU 占用率超过某个值的进程(注意,要带上小数位):

%CPU>5.0

按下 ctrl + o 可以查看当前的过滤条件:

可以连续添加多个过滤条件,这些过滤条件会同时起作用。按下 = 则会清除所有的过滤条件。

top 命令的配置文件

top 命令是有配置文件的,也就是说你通过命令修改的配置都可以保存下来。保存配置的命令为大写字母 W。在你修改了 top 命令的配置后按下大写字母 W,然后退出 top 命令并再次执行 top 命令,此时你的修改仍然在起作用。

帮助文档

帮助文档永远都是我们的好朋友,小写字母 h 或者是 ? 可以打开 top 命令的帮助文档。不要太惊奇,文档有点长哟!

来源: https://www.cnblogs.com/sparkdev/p/8176778.html

-------------------------------------------------------------------------------------------------------------------------------------------------

Linux进程查看命令
PS命令
1.不带参数的ps使用

2.显示所有的当前进程

ps –ax  -a 代表 all。同时加上x参数会显示没有控制终端的进程。
ps -ax | less 可以结合less命令和管道来使用以方便查看。
1
2
3.通过cpu和内存使用来过滤进程

ps -aux | less
默认的结果集是未排好序的。可以通过 –sort命令来排序。
根据 CPU 使用来升序排序
ps -aux --sort -pcpu | less
根据 内存使用 来升序排序
ps -aux --sort -pmem | less
我们也可以将它们合并到一个命令,并通过管道显示前10个结果:
ps -aux --sort -pcpu,+pmem | head -n 10
1
2
3
4
5
6
7
8
9
4.通过进程名和PID过滤

ps -f -C [进程名]
ps -f -C mysqld
1
2


5.树形显示进程

6.查看所有关于java的进程

ps -ef | grep java
1
top命令
1.top命令经常用来监控Linux的系统状况,比如cpu、内存的使用。

2.第一行:

第一块:当前系统时间
第二块:系统已经运行了3天23小时26分
第三块:当前有1个用户登录系统
第四块:load average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。
1
2
3
4
3.第二行:

第一块:系统现在有431个进程
第二块:有一个进程处于运行状态
第三块:428个进程处于休眠状态
第四块:0个进程处于stopped状态
第五块:2个进程处于zombie状态
1
2
3
4
5
4.第三行:cpu状态

0.4 us — 用户空间占用CPU的百分比。
0.5 sy — 内核空间占用CPU的百分比。
0.0 ni — 改变过优先级的进程占用CPU的百分比
99.0 id — 空闲CPU百分比
0.0 wa — IO等待占用CPU的百分比
0.0 hi — 硬中断(Hardware IRQ)占用CPU的百分比
0.0 si — 软中断(Software Interrupts)占用CPU的百分比
用户空间就是用户进程所在的内存区域,相对的,系统空间就是操作系统占据的内存区域。用户进程和系统进程的所有数据都在内存中。
1
2
3
4
5
6
7
8
5.第四行:内存状态(单位k)

16237008 total — 物理内存总量(16.2GB)
10904524 used — 使用中的内存总量(10.9GB)
1984320  free — 空闲内存总量(2.0G)
3348164  buffers — 缓存的内存量 (3.3G)
1
2
3
4
6.第五行:swap交换分区

5119996 total — 交换区总量(5GB)
0       used — 使用的交换区总量(0)
5119996 free — 空闲交换区总量(5GB)
4800960 cached — 缓冲的交换区总量(4.8GB)
1
2
3
4
可用内存数的近似的计算公式:第四行的free + 第四行的buffers + 第五行的cached。
我们最关心的内存监控是第五行swap(类似于虚拟内存)交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是可以判定服务器的内存不够用了。

7.第六行:各进程(任务)的状态监控

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 — 进程名称(命令名/命令行)
1
2
3
4
5
6
7
8
9
10
11
12
线程查看命令
top –H(列出所有的线程)


让top输出某个特定进程[pid]并检查该进程内运行的线程状况
```
让top输出某个特定进程[pid]并检查该进程内运行的线程状况:
top -H -p [pid]

```
1
2
3
4
5


查看由进程号为[pid]的进程创建的所有线程
```
ps -T -p [pid]
```
1
2
3


Java线程监控分析(一般流程)
1.先用top命令找出占用资源比较多的java进程id

我们以第一个进程为例,对该进程的所有线程进行监控

2.查看相关进程的所有线程

接下来我们以第一个线程为例,对其进行监控分析

3.然后借助JVM的 jconsole.exe 工具对相应线程进行具体分析
————————————————
版权声明:本文为CSDN博主「Robin_Liew」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/liubin1991liubin/article/details/79702640

以上是 linuxtop命令 的全部内容, 来源链接: utcz.com/z/514425.html

回到顶部