top - 11:19:59 up 72 days, 4:35, 1 user, load average: 0.09, 0.08, 0.08
Tasks: 115 total, 1 running, 114 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.3%us, 0.1%sy, 0.0%ni, 99.5%id, 0.1%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 12253052k total, 10055704k used, 2197348k free, 3668848k buffers
Swap: 8289532k total, 0k used, 8289532k free, 2821828k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
14316 daemon 18 0 609m 101m 9676 S 1 0.9 0:31.41 httpd
15159 daemon 18 0 607m 98m 9280 S 1 0.8 0:28.81 httpd
13859 daemon 18 0 660m 87m 9328 S 0 0.7 0:36.99 httpd
14062 daemon 18 0 599m 90m 9596 S 0 0.8 0:33.34 httpd
14288 daemon 18 0 609m 102m 9524 S 0 0.9 0:39.06 httpd
14344 daemon 18 0 597m 89m 9512 S 0 0.7 0:31.73 httpd
15131 daemon 18 0 608m 98m 9404 S 0 0.8 0:30.37 httpd
1 root 15 0 10324 688 580 S 0 0.0 0:03.07 init
2 root RT -5 0 0 0 S 0 0.0 0:02.12 migration/0
3 root 34 19 0 0 0 S 0 0.0 0:00.06 ksoftirqd/0
4 root RT -5 0 0 0 S 0 0.0 0:00.00 watchdog/0
5 root RT -5 0 0 0 S 0 0.0 0:02.01
migration/1
6 root 34 19 0 0 0 S 0 0.0 0:00.03
ksoftirqd/1
7 root RT -5 0 0 0 S 0 0.0 0:00.00 watchdog/1
kblockd/4
Current Fields: AEHIOQTWKNMbcdfgjplRsuvyzX for window 1:Def
Toggle fields via field letter, type any other key to return
* A: PID = Process Id
* E: USER = User Name
* H: PR = Priority
* I: NI = Nice value
* O: VIRT = Virtual Image (kb)
* Q: RES = Resident size (kb)
* T: SHR = Shared Mem size (kb)
* W: S = Process Status
* K: %CPU = CPU usage
* N: %MEM = Memory usage (RES)
* M: TIME+ = CPU Time, hundredths
b: PPID = Parent Process Pid
c: RUSER = Real user name
d: UID = User Id
f: GROUP = Group Name
g: TTY = Controlling Tty
j: P = Last used cpu (SMP)
p: SWAP = Swapped size (kb)
l: TIME = CPU Time
* R: CODE = Code size (kb)
s: DATA = Data+Stack size (kb)
u: nFLT = Page Fault count
v: nDRT = Dirty Pages count
y: WCHAN = Sleeping in Function
z: Flags = Task Flags <sched.h>
* X: COMMAND = Command name/line
Flags field:
0x00000001 PF_ALIGNWARN
0x00000002 PF_STARTING
0x00000004 PF_EXITING
0x00000040 PF_FORKNOEXEC
0x00000100 PF_SUPERPRIV
0x00000200 PF_DUMPCORE
0x00000400 PF_SIGNALED
0x00000800 PF_MEMALLOC
0x00002000 PF_FREE_PAGES (2.5)
0x00008000 debug flag (2.5)
0x00024000 special threads (2.5)
0x001D0000 special states (2.5)
0x00100000 PF_USEDFPU (thru 2.4)
第一行:
10:01:23 — 当前系统时间
126 days, 14:29 — 系统已经运行了126天14小时29分钟(在这期间没有重启过)
2 users — 当前有2个用户登录系统
load average: 1.15, 1.42, 1.44 — load average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。
load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。
第二行:
Tasks — 任务(进程),系统现在共有183个进程,其中处于运行中的有1个,182个在休眠(sleep),stoped状态的有0个,zombie状态(僵尸)的有0个。
第三行:cpu状态
6.7% us — 用户空间占用CPU的百分比。
0.4% sy — 内核空间占用CPU的百分比。
0.0% ni — 改变过优先级的进程占用CPU的百分比
92.9% id — 空闲CPU百分比
0.0% wa — IO等待占用CPU的百分比
0.0% hi — 硬中断(Hardware IRQ)占用CPU的百分比
0.0% si — 软中断(Software Interrupts)占用CPU的百分比
在这里CPU的使用比率和windows概念不同,如果你不理解用户空间和内核空间,需要充充电了。
第四行:内存状态
8306544k total — 物理内存总量(8GB)
7775876k used — 使用中的内存总量(7.7GB)
530668k free — 空闲内存总量(530M)
79236k buffers — 缓存的内存量 (79M)
第五行:swap交换分区
2031608k total — 交换区总量(2GB)
2556k used — 使用的交换区总量(2.5M)
2029052k free — 空闲交换区总量(2GB)
4231276k cached — 缓冲的交换区总量(4GB)
这里要说明的是不能用windows的内存概念理解这些数据,如果按windows的方式此台服务器“危矣”:8G的内存总量只剩下530M的可用内存。Linux的内存管理有其特殊性,复杂点需要一本书来说明,这里只是简单说点和我们传统概念(windows)的不同。
第
四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见
得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越
来越少,但不用为此担心。
如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四行的free + 第四行的buffers + 第五行的cached,按这个公式此台服务器的可用内存:530668+79236+4231276 = 4.7GB。
对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。
第六行是空行
第七行以下:
各进程(任务)的状态监控
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 — 进程名称(命令名/命令行)
top命令的补充
top 命令是Linux上进行系统监控的首选命令,但有时候却达不到我们的要求,比如当前这台服务器,top监控有很大的局限性。这台服务器运行着 websphere集群,有两个节点服务,就是【top视图 01】中的老大、老二两个java进程,top命令的监控最小单位是进程,所以看不到我关心的java线程数和客户连接数,而这两个指标是java的 web服务非常重要的指标,通常我用ps和netstate两个命令来补充top的不足。
监控java线程数:
ps -eLf | grep java | wc -l
监控网络客户连接数:
netstat -n | grep tcp | grep 侦听端口 | wc -l
上面两个命令,可改动grep的参数,来达到更细致的监控要求。
在 Linux系统“一切都是文件”的思想贯彻指导下,所有进程的运行状态都可以用文件来获取。系统根目录/proc中,每一个数字子目录的名字都是运行中的进程的PID,进入任一个进程目录,可通过其中文件或目录来观察进程的各项运行指标,例如task目录就是用来描述进程中线程的,因此也可以通过下面的方法获取某进程中运行中的线程数量(PID指的是进程ID):
ls /proc/PID/task | wc -l
在linux中还有一个命令pmap,来输出进程内存的状况,可以用来分析线程堆栈:
pmap PID
分享到:
相关推荐
标题和描述中的"图解linux下top命令的使用"意味着本文将通过实例和图形解释如何使用`top`命令来监控Linux系统。 **1. top命令的基本视图解析:** - **第一行**:显示当前系统时间以及系统已运行的时间,这里的...
- **系统信息命令**:如`uname`、`top`、`df`和`free`,获取系统信息和监控资源使用情况。 - **网络命令**:`ping`、`ifconfig`、`nslookup`等,检查网络连接和IP地址。 - **权限管理**:理解`chmod`和`chown`,...
《练成Linux系统高手》是一本专为Linux初学者和中级学习者设计的教程,全程图解的方式使得学习过程更为直观易懂。本书涵盖了从基础知识到深入技术的全面内容,旨在帮助读者逐步提升Linux技术水平,成为一名熟练的...
本文将深入探讨“Linux命令学习大全”这一主题,基于提供的压缩包文件内容,包括“Red Hat Enterprise Linux AS 4图解教程之Linux基本操作.pdf”、“Linux系统常用命令快速入门.pdf”以及“Linux命令学习大全.pdf”...
这个压缩包包含了与这些主题相关的资源,包括“Linux命令大全”的CHM文件、PDF文档以及DOS命令的参考资料,还有VMware与Red Hat安装的详细图解。以下是这些资源所涵盖的主要知识点: 1. **Linux命令大全**: Linux...
1. Red Hat Linux 9.0使用RPM包管理系统,可以通过`rpm`命令安装、查询、升级软件。 2. `yum`工具可以在线更新和安装软件包,通过`yum update`保持系统最新。 3. 配置 `/etc/yum.repos.d/` 目录下的仓库文件,添加第...
《实例图解 RedHat Linux 9.0 应用指南》是针对Red Hat Linux操作系统的一份详尽教程,尤其适合初学者和有一定基础的用户。本指南分为四集,其中第4集是整个系列的最后部分,可能涵盖高级主题和实践操作。Red Hat ...
学习如何使用`top`、`ps`和`kill`命令。此外,还将介绍日志管理、定时任务(cron)以及硬件管理。 5. **网络服务**:配置网络接口,学会使用`ifconfig`和`route`命令。了解DNS解析,设置DHCP或静态IP。学习如何启动...
9. **进程管理和任务调度**:了解`ps`, `top`, `kill`等命令用于监控和控制进程,以及如何使用`crontab`设置定期任务。 10. **系统日志和故障排查**:学习查看和分析系统日志(如`/var/log`下的日志文件),并利用...
通过命令行,我们可以监控系统状态,如使用top或htop查看系统资源占用,用df和du检查磁盘空间,使用crontab设置定时任务等。 总的来说,"LAMP->1之linux安装与操作"是一个全面学习Linux基础和搭建Web服务器平台的...
- 监控数据库性能,使用`gdb`, `top`, `iostat`等工具进行性能分析。 这个过程涉及的内容较多,每一步都需要细心操作。如果你遵循这些步骤并仔细阅读提供的PDF教程,应该能够在CentOS 7上成功安装并运行Oracle 11...