赞
踩
Top 命令能够实时监控系统的运行状态,并且可以按照cpu、内存和执行时间进行排序
1.全局命令
2.摘要区命令
1 : 汇总显示CPU状态或分开显示每个CPU状态
1.任务区命令
Free命令是监控系统内存最常用的命令
-m:以M为单位查看内存使用情况(默认为kb)
-b:以字节为单位查看内存使用情况
-s:可以在指定时间段内不简单监控内存的使用情况
可以监控操作系统的进程状态、内存、虚拟内存、磁盘IO、上下文、CPU的信息。
vmstat [-a] [-n] [-S unit] [delay [ count]]
Procs
R:等待被执行的进程数,即表示运行和等待CPU时间片的进程数
B:排队的进程数,即等待资源的进程数
Memory
Swap : 虚拟内存,切换到虚拟内存的内存大小
Free: 空闲的物理内存大小
Buff: 缓冲区大小
Cache: 缓存大小
Swap
Si:磁盘写入虚拟内存,即由内存进入到虚拟内存的大小。
So:虚拟内存写入磁盘,即由虚拟内存进入到磁盘的大小。
Io
Bi:由块设备读入的数据总量,读磁盘
Bo:由块设备写入的数据总量,写磁盘
System
In: 每秒设备中断数
Cs:每秒上下文切换的次数
Cpu
Us:用户进程消耗cpu百分比
Sy:内核进程消耗cpu百分比
Id:cpu处于空闲状态的时间百分比
Wa:Io等待cpu所占时间的百分比
Iostat是对系统磁盘IO操作进行监控,它的输出主要显示磁盘的读写操作的统计信息。同时给出cpu的使用情况
iostat [ -c | -d ] [ -k | -m ] [ -t ] [ -V ] [ -x ] [ device [ ... ] | ALL ] [ -p [ device | ALL ] ] [ interval [ count ] ]
各选项以及参数含义如下:
或显示所有设备
# iostat -p ALL
-t :在输出数据时,打印搜集数据的时间.
-V :打印版本号和帮助信息.
-x device 输出指定要统计的磁盘设备名称,默认为所有磁盘设备.
- interval :指两次统计间隔时间
- count :按照interval 指定的时间间隔统计的次数
Iostat的简单应用
Iostat磁盘监控
Iostat cpu 监控
Mpstat可以监控到cpu的一些统计信息,在多核cpu的系统里不但能够查看所有cpu的平均状况信息,而且能够查看特定的cpu的信息
mpstat [-P {|ALL}] [internal [count]]
参数:
(1)-P {|ALL}:表示监控哪个CPU,在[0,cpu个数-1]中取值;
(2)internal:相邻的两次采样的间隔时间;
(3)count:采样的次数,count只能和delay一起使用;
备注:当没有参数时,mpstat则显示系统启动以后所有信息的平均值。有interval时,第一行的信息自系统启动以来的平均信息。从第二行开始,输出为前一个interval时间段的平均信息。
(1)user:在internal时间段里,用户态的CPU时间(%),不包含nice值为负进程,值为 (usr/total)*100;
(2)nice:在internal时间段里,nice值为负进程的CPU时间(%),值为(nice/total)*100;
(3)system:在internal时间段里,核心时间(%),值为(system/total)*100;
(4)iowait:在internal时间段里,硬盘IO等待时间(%),值为(iowait/total)*100;
(5)irq:在internal时间段里,硬中断时间(%),值为(irq/total)*100;
(6)soft:在internal时间段里,软中断时间(%),值为(softirq/total)*100;
(7)idle:在internal时间段里,CPU除去等待磁盘IO操作外的因为任何原因而空闲的时间闲置时间(%),值为(idle/total)*100;
(8)intr/s:在internal时间段里,每秒CPU接收的中断的次数,值为(intr/total)*100;
Sar命令可以全名的获取到cpu 、运行、磁盘IO、虚拟内存、内存、网络等信息。
sar 命令行的常用格式:
sar [options] [-A] [-o file] t [n]
在命令行中,n 和t 两个参数组合起来定义采样间隔和次数,t为采样间隔,是必须有的参数,n为采样次数,是可选的,默认值是1,-o file表示将命令结果以二进制格式存放在文件中,file 在此处不是关键字,是文件名。options 为命令行选项,sar命令的选项很多,下面只列出常用选项:
Cpu资源监控
CPU:all 表示统计信息为所有 CPU 的平均值。
%user:显示在用户级别(application)运行使用 CPU 总时间的百分比。
%nice:显示在用户级别,用于nice操作,所占用 CPU 总时间的百分比。
%system:在核心级别(kernel)运行所使用 CPU 总时间的百分比。
%iowait:显示用于等待I/O操作占用 CPU 总时间的百分比。
%steal:管理程序(hypervisor)为另一个虚拟进程提供服务而等待虚拟 CPU 的百分比。
%idle:显示 CPU 空闲时间占用 CPU 总时间的百分比。
1. 若 %iowait 的值过高,表示硬盘存在I/O瓶颈
2. 若 %idle 的值高但系统响应慢时,有可能是 CPU 等待分配内存,此时应加大内存容量
1. 若 %idle 的值持续低于1,则系统的 CPU 处理能力相对较低,表明系统中最需要解决的资源是 CPU 。
如果要查看二进制文件test中的内容,需键入如下sar命令:
sar -u -f test
Inode、文件和其他内核表监控
Dentunued: 目录告诉缓存中未被使用的条目数量
File-nr: 文件句柄的使用数量
Inode-nr: 索引节点句柄的使用数量
Pty-nr :使用的pty的数量
内存和交换空间监控
kbmemfree:这个值和free命令中的free值基本一致,所以它不包括buffer和cache的空间.
kbmemused:这个值和free命令中的used值基本一致,所以它包括buffer和cache的空间.
%memused:这个值是kbmemused和内存总量(不包括swap)的一个百分比.
kbbuffers和kbcached:这两个值就是free命令中的buffer和cache.
kbcommit:保证当前系统所需要的内存,即为了确保不溢出而需要的内存(RAM+swap).
%commit:这个值是kbcommit与内存总量(包括swap)的一个百分比.
内存分页监控
pgpgin/s:表示每秒从磁盘或SWAP置换到内存的字节数(KB)
pgpgout/s:表示每秒从内存置换到磁盘或SWAP的字节数(KB)
fault/s:每秒钟系统产生的缺页数,即主缺页与次缺页之和(major + minor)
majflt/s:每秒钟产生的主缺页数.
pgfree/s:每秒被放入空闲队列中的页个数
pgscank/s:每秒被kswapd扫描的页个数
pgscand/s:每秒直接被扫描的页个数
pgsteal/s:每秒钟从cache中被清除来满足内存需要的页个数
%vmeff:每秒清除的页(pgsteal)占总扫描页(pgscank+pgscand)的百分比
IO和传送速率监控
tps:每秒钟物理设备的 I/O 传输总量
rtps:每秒钟从物理设备读入的数据总量
wtps:每秒钟向物理设备写入的数据总量
bread/s:每秒钟从物理设备读入的数据量,单位为 块/s
bwrtn/s:每秒钟向物理设备写入的数据量,单位为 块/s
进程队列长度和平均负载状态监控
runq-sz:运行队列的长度(等待运行的进程数)
plist-sz:进程列表中进程(processes)和线程(threads)的数量
ldavg-1:最后1分钟的系统平均负载(System load average)
ldavg-5:过去5分钟的系统平均负载
ldavg-15:过去15分钟的系统平均负载
系统交换活动信息监控
pswpin/s:每秒系统换入的交换页面(swap page)数量
pswpout/s:每秒系统换出的交换页面(swap page)数量
设备使用情况监控
参数-p可以打印出sda,hdc等磁盘设备名称,如果不用参数-p,设备节点则有可能是dev8-0,dev22-0
tps:每秒从物理磁盘I/O的次数.多个逻辑请求会被合并为一个I/O磁盘请求,一次传输的大小是不确定的.
rd_sec/s:每秒读扇区的次数.
wr_sec/s:每秒写扇区的次数.
avgrq-sz:平均每次设备I/O操作的数据大小(扇区).
avgqu-sz:磁盘请求队列的平均长度.
await:从请求磁盘操作到系统完成处理,每次请求的平均消耗时间,包括请求队列等待时间,单位是毫秒(1秒=1000毫秒).
svctm:系统处理每次请求的平均时间,不包括在请求队列中消耗的时间.
%util:I/O请求占CPU的百分比,比率越大,说明越饱和.
1. avgqu-sz 的值较低时,设备的利用率较高。
2. 当%util的值接近 1% 时,表示设备带宽已经占满。
Netstat 命令用于显示本机网络链接、运行端口、路由表等信息
netstat [选项]
提示:LISTEN和LISTENING的状态只有用-a或者-l才能看到
B 已经设置了一个广播地址。
L 该接口是一个回送设备。
M 接收所有数据包(混乱模式)。
N 避免跟踪。
O 在该接口上,禁用A R P。
P 这是一个点到点链接。
R 接口正在运行。
U 接口处于“活动”状态。
其中RX-ERR/TX-ERR、 RX-DRP/TX-DRP和RX-OVR/TX-OVR的值应该都为0,如果不为0,并且很大,那么网络质量肯定有问题,网络传输性能也一代会下降。
LISTEN :在监听状态中。
ESTABLISHED:已建立联机的联机情况。
TIME_WAIT:该联机在目前已经是等待的状态。
Uptime主要是用来统计系统当前的运行状态
-V 显示版本
Ps命令是进程查看命令,使用这个命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等。
常用参数:
常用用法:
最常用的方法是ps -aux,然后再利用一个管道符号导向到grep去查找特定的进程,然后再对特定的进程进行操作。
实时监测命令,还可以检测其他命令运行情况的命令
-d 高亮显示变动
-n 周期(秒)
Watch –d –n 1 netstat -ant
每秒监测网络,高亮显示变化。
Strace命令用来跟踪进程执行时的系统调用和所接收的信号。在Linux世界,进程不能直接访问硬件设备,当进程需要访问硬件设备(比如读取磁盘文件,接收网络数据等等)时,必须由用户态模式切换至内核态模式,通过系统调用访问硬件设备。strace可以跟踪到一个进程产生的系统调用,包括参数,返回值,执行消耗的时间
strace使用参数
strace -ff -F -o ls.log ls –l 跟踪ls –l命令的执行情况
当某个函数执行失败时,那么返回值一般为-1
Lsof的原始功能是列出打开的文件的进程。Linux下一切皆文件。
列出所有root用户下的socket文件进程
http://www.cnblogs.com/lingfengblogs/p/4158727.html
如有遗漏处,欢迎评论,逐渐补充。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。