如何写论文?写好论文?免费论文网提供各类免费论文写作素材!
当前位置:免费论文网 > 美文好词 > 优质好文 > linux下top命令

linux下top命令

来源:免费论文网 | 时间:2017-05-08 07:24 | 移动端:linux下top命令

篇一:LINUX TOP命令

Linux top命令的用法详细详解

TOP

这里要说明的是不能用windows的内存概念理解这些数据,如果按windows的方式此台服务器“危矣”:8G的内存总量只剩下530M的可用内存。

Linux的内存管理有其特殊性,复杂点需要一本书来说明,这里只是简单说点和我们传统概念(windows)的不同。 第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。

如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四行的free + 第四行的buffers + 第五行的cached,按这个公式此台服务器的可用内存:530668+79236+4231276 = 4.7GB。

对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。

代码如下:

篇二:linux下top命令及参数解析

Top命令解析

Top命令是linux 下常用的系统性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于windows的任务管理器。下面详细介绍它的使用方法。

下面是top命令的部分截图:

第一行 分别显示:系统当前时间 系统运行时间 当前用户登陆数 系统负载。

*系统负载(load average),这里有三个数值,分别是系统最近1分钟,5分钟,15分钟的平均负载。一般对于单个处理器来说,负载在0 — 1.00 之间是正常的,超过1.00就要引起注意了。在多核处理器中,你的系统均值不应该高于处理器核心的总数。

第二行 分别显示:total进程总数、 running正在运行的进程数、 sleeping睡眠的进程数、 stopped停止的进程数、 zombie僵尸进程数。

第三行 分别显示:%us (user) 用户空间占用CPU百分比、%sy (system) 内核空间占用CPU百分比、%ni 用户进程空间内改变过优先级的进程占用CPU百分比、 %id (idle) 空闲CPU百分比、%wa (wait) 等待输入输出(I/O)的CPU时间百分比 、%hi (hardware interrupt) 指的是cpu处理硬件中断的时间、%si (software interrupt) 指的是cpu处理软中断的时间 、%st (suppositional) 用于有虚拟cpu的情况,用来指示被虚拟机偷掉的cpu时间。

通常id%值可以反映一个系统cpu的闲忙程度。

第四行 MEM :total 物理内存总量、 used 使用的物理内存总量、

free 空闲内存总量、 buffers 用作内核缓存的内存量。

第五行 SWAP:total 交换区总量、 used 使用的交换区总量、

free 空闲交换区总量、 cached 缓冲的交换区总量。

buffers和cached的区别需要说明一下,buffers指的是块设备的读写缓冲区,cached指的是文件系统本身的页面缓存。它们都是linux操作系统底层的机制,目的就是为了加速对磁盘的访问。

第六行 PID(进程号)、 USER(运行用户)、PR(优先级)、NI(任务nice值)、VIRT(虚拟内存用量)VIRT=SWAP+RES 、RES(物理内存用量)、SHR(共享内存用量)、S(进程状态)、%CPU(CPU占用比)、%MEM(物理内存占用比)、TIME+(累计CPU占用时间)、 COMMAND 命令名/命令行。

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

下面简单介绍top命令的使用方法:

top [-] [d] [p] [q] [c] [C] [S] [s] [n]

参数说明

d 指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。 p 通过指定监控进程ID来仅仅监控某个进程的状态。

q该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。

S 指定累计模式。

s 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。

i 使top不显示任何闲置或者僵死进程。

c 显示整个命令行而不只是显示命令名。

下面介绍在top命令执行过程中可以使用的一些交互命令。从使用角度来看,熟练的掌握这些命令比掌握选项还重要一些。这些命令都是单字母的,如果在命令行选项中使用了s选项,则可能其中一些命令会被屏蔽掉。

Ctrl+L 擦除并且重写屏幕。

h或者? 显示帮助画面,给出一些简短的命令总结说明。

k 终止一个进程。系统将提示用户输入需要终止的进程PID,以及需要发送给该进程什么样的信号。一般的终止进程可以使用15信号;如果不能正常结束那就使用信号9强制结束该进程。默认值是信号15。在安全模式中此命令被屏蔽。

i 忽略闲置和僵死进程。这是一个开关式命令。

q 退出程序。

r 重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。

s 改变两次刷新之间的延迟时间。系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s。需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加。

f或者F 从当前显示中添加或者删除项目。

o或者O 改变显示项目的顺序。

l 切换显示平均负载和启动时间信息。

m 切换显示内存信息。

t 切换显示进程和CPU状态信息。

c 切换显示命令名称和完整命令行。

M 根据驻留内存大小进行排序。

P 根据CPU使用百分比大小进行排序。

T 根据时间/累计时间进行排序。

W 将当前设置写入~/.toprc文件中。这是写top配置文件的推荐方法。

Shift+M 可按内存占用情况进行排序。

篇三:linux top命令介绍

linux top命令介绍

top:动态观察程序的变化

[root@linux ~]# top [-d] | top [-bnp]

参数:

-d :后面可以接秒数,就是整个程序画面更新的秒数。预设是 5 秒; -b :以批次的方式执行 top ,还有更多的参数可以使用喔!

通常会搭配数据流重导向来将批次的结果输出成为档案。

-n :与 -b 搭配,意义是,需要进行几次 top 的输出结果。

-p :指定某些个 PID 来进行观察监测而已。

在 top 执行过程当中可以使用的按键指令:

? :显示在 top 当中可以输入的按键指令;

P :以 CPU 的使用资源排序显示;

M :以 Memory 的使用资源排序显示;

N :以 PID 来排序喔!

T :由该 Process 使用的 CPU 时间累积 (TIME+) 排序。

k :给予某个 PID 一个讯号 (signal)

r :给予某个 PID 重新制订一个 nice 值。

范例1:每两秒钟更新一次 top ,观察整体信息

[root@linux ~]# top -d 2

top - 18:30:36 up 30 days, 7 min, 1 user, load average: 0.42, 0.48, 0.45 Tasks: 163 total, 1 running, 161 sleeping, 1 stopped, 0 zombie

Cpu(s): 4.7% us, 4.0% sy, 6.3% ni, 82.5% id, 0.4% wa, 0.1% hi, 2.0% si Mem: 1033592k total, 955252k used, 78340k free, 208648k buffers Swap: 1052216k total, 728k used, 1051488k free, 360248k cached <==如果加入 k 或 r 时,就会有相关的字样出现在这里喔!

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

3981 apache 34 19 84012 11m 7352 S 17.3 1.2 0:00.09 httpd

1454 mysql 16 0 289m 40m 2228 S 3.8 4.0 115:01.32 mysqld

3985 dmtsai 15 0 2148 904 668 R 3.8 0.1 0:00.03 top

1 root 16 0 3552 552 472 S 0.0 0.1 0:08.90 init

2 root RT 0 0 0 0 S 0.0 0.0 0:52.76 migration/0

3 root 34 19 0 0 0 S 0.0 0.0 0:03.01 ksoftirqd/0

范例2:将 top 的信息进行 2 次,然后将结果输出到 /tmp/top.txt

[root@linux ~]# top -b -n 2 > /tmp/top.txt

# 这样一来,嘿嘿!就可以将 top 的信息存到 /tmp/top.txt 档案中了。

范例3:假设 10604 是一个已经存在的 PID ,仅观察该程序?

[root@linux ~]# top -d 2 -p10604

top - 13:53:00 up 51 days, 2:27, 1 user, load average: 0.00, 0.00, 0.00 Tasks: 1 total, 0 running, 1 sleeping, 0 stopped, 0 zombie

Cpu(s): 0.0% us, 0.0% sy, 0.0% ni, 100.0% id, 0.0% wa, 0.0% hi, 0.0% si Mem: 385676k total, 371760k used, 13916k free, 131164k buffers Swap: 1020116k total, 880k used, 1019236k free, 95772k cached

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

10604 root 16 0 5396 1544 1244 S 0.0 0.4 0:00.07 bash

范例四:承上题,上面的 NI 值是 0 ,想要改成 10 的话?

# 在范例三的 top 画面当中直接按下 r 之后,会出现如下的图样!

top - 13:53:00 up 51 days, 2:27, 1 user, load average: 0.00, 0.00, 0.00 Tasks: 1 total, 0 running, 1 sleeping, 0 stopped, 0 zombie

Cpu(s): 0.0% us, 0.0% sy, 0.0% ni, 100.0% id, 0.0% wa, 0.0% hi, 0.0% si Mem: 385676k total, 371760k used, 13916k free, 131164k buffers Swap: 1020116k total, 880k used, 1019236k free, 95772k cached PID to renice: 10604

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

10604 root 16 0 5396 1544 1244 S 0.0 0.4 0:00.07 bash

# 之后,可以输入 nice 值了!

top - 13:53:00 up 51 days, 2:27, 1 user, load average: 0.00, 0.00, 0.00 Tasks: 1 total, 0 running, 1 sleeping, 0 stopped, 0 zombie

Cpu(s): 0.0% us, 0.0% sy, 0.0% ni, 100.0% id, 0.0% wa, 0.0% hi, 0.0% si Mem: 385676k total, 371760k used, 13916k free, 131164k buffers Swap: 1020116k total, 880k used, 1019236k free, 95772k cached Renice PID 10604 to value: 10

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

10604 root 30 10 5396 1544 1244 S 0.0 0.4 0:00.07 bash

top 也是个挺不错的程序观察工具!但不同于 ps 是静态的结果输出, top 这个程序可以持续的监测 (monitor) 整个系统的程序工作状态,例如上面的范例一所示啊! 在预设的情况下,每次更新程序资源的时间为 5 秒,不过,可以使用 -d 来进行修改。 top 主要分为两个画面,上面的画面为整个系统的资源使用状态,基本上总共有六行, 显示的内容依序是:

? 第一行:显示系统已启动的时间、目前上线人数、系统整体的负载(load)。 比较需要注意的是系统的负载,三个数据分别代表 1, 5, 10 分钟的平均负载。 一

般来说,这个负载值应该不太可能超过 1 才对,除非您的系统很忙碌。 如果持续高于 5 的话,那么.....仔细的看看到底是那个程序在影响整体系统吧! ? 第二行:显示的是目前的观察程序数量,比较需要注意的是最后的 zombie 那个数值,如果不是 0 ,嘿嘿!好好看看到底是那个 process 变成疆尸了吧?! ? 第三行:显示的是 CPU 的整体负载,每个项目可使用 ? 查阅。需要观察的是 id (idle) 的数值,一般来说,他应该要接近 100% 才好,表示系统很少资源被使用啊! ^_^。

? 第四行与第五行:表示目前的物理内存与虚拟内存 (Mem/Swap) 的使用情况。 ? 第六行:这个是当在 top 程序当中输入指令时,显示状态的地方。 例如范例四就是一个简单的使用例子。

至于 top 底下的画面,则是每个 process 使用的资源情况。比较需要注意的是: ? PID :每个 process 的 ID 啦!

? USER:该 process 所属的使用者;

? PR :Priority 的简写,程序的优先执行顺序,越小越早被执行; ? NI :Nice 的简写,与 Priority 有关,也是越小越早被执行;

? %CPU:CPU 的使用率;

? %MEM:内存的使用率;

? TIME+:CPU 使用时间的累加;

一般来说,如果想要找出最损耗 CPU 资源的那个程序时,大多使用的就是 top 这支程序啦!然后强制以 CPU 使用资源来排序 (在 top 当中按下 P 即可), 就可以很快的知道啦! ^_^。多多爱用这个好用的东西喔!


linux下top命令》由:免费论文网互联网用户整理提供;
链接地址:http://www.csmayi.cn/meiwen/34260.html
转载请保留,谢谢!
相关文章