iostat命令简单使用
1.iostat使用范围
iostat命令可以生成3种类型的报告:
(1)CPU使用情况的报告
(2)设备使用情况的报告
(3)网络文件系统(NFS)使用情况的报告
2.每种报告的格式说明
关于CPU使用报告的格式解释:
%user:应用程序使用CPU的时间占比。
%nice:拥有高优先级的应用程序占用CPU的时间百分比。
默认情况下,所有应用程序的优先级一样,所以CPU不会偏袒哪一个。但如果有的优先级高,CPU就会先
去执行它们,那么对于这群身份特殊的应用程序,我们用%nice来统计它们的CPU使用占比。
%system:内核程序使用CPU的时间占比。
%iowait:CPU花费了多少时间去等待磁盘IO。此时CPU是空闲的,什么事都不做。
%idle:CPU什么都不做,既没有等待磁盘IO,也没有做其他事情。完全空闲状态。
%steal:之前管理程序服务于CPU1,突然CPU2跑来了,此时管理程序跟CPU1说:你等会哈,我先去服务CPU2,马上回来。
此时,CPU1被强制置于等待状态。CPU1等待的时间占比就是%steal。(个人理解)
关于设备使用报告的格式解释:
tps:每秒发送给设备的传输数。这里的传输指的是:发给设备的一个I/O请求。
所以,tps的意思就是:每秒发给设备的I/O请求数。一个读请求叫做一个I/0,一个写请求也叫做一个I/O。
Blk_read/s:每秒从设备读取的block数。每个block的大小是512字节,等于一个扇区的大小。
Blk_wrtn/s:每秒写入到设备的block数。每个block的大小是512字节,等于一个扇区的大小。
Blk_read:从该设备读取的总block数。发出去的block数。
Blk_wrtn:写入到该设备的总block数。拿进来的block数。
kB_read/s:每秒从设备读取的千字节数。kilobytes。
kB_wrtn/s:每秒写入到设备的千字节数。kilobytes。
kB_read:从设备读取的总千字节数。kilobytes。发出去的数据量。
kB_wrtn:写入到该设备的总千字节数。kilobytes。拿进来的数据量。
MB_read/s:每秒从该设备读出去的兆字节数。megabytes。
MB_wrtn/s:每秒写入到该设备的兆字节数。megabytes。
MB_read:从该设备读出去的总兆字节数。
MB_wrtn:写入到该设备的总兆字节数。
rrqm/s:没有理解,会查找资料来补充。
wrqm/s:没有理解,会查找资料来补充。
r/s:每秒发送给设备的读请求数。(重要指标)
w/s:每秒发送给设备的写请求数。(重要指标)
rsec/s:每秒从这个设备读取了多少个扇区。
wsec/s:每秒写入了多少个扇区到该设备。
rkB/s:每秒从设备读取的千字节数。kilobytes。(与前面的kB_read/s一样)
wkB/s:每秒写入到设备的千字节数。kilobytes。(与前面的kB_write/s一样)
rMB/s:与上面类似。
wMB/s:与上面类似。
avgrq-sz:所有发送给设备的请求,都有大小。这个参数用于表示所有请求的平均大小,以扇区为单位。
avgqu-sz:假如第1秒,设备前的请求队列中有5个请求;第2秒,设备前的队列中有4个请求;
第3秒,设备前的请求队列中有3个请求,那么现在我来计算,设备前的队列,平均每秒是多长:
5 + 4 + 3 / 3 = 4。也就是平均每秒都有4个请求在排队。
await:设备服务每个请求的平均时间。包括请求的排队时间和实际服务时间。比如我去肯德基,
我的前面有4个人,排了15分钟后,服务员开始给我服务。我点了汉堡和可乐,过
了5分钟,服务员将汉堡和可乐交给了我,我拿着东西离开了。所以对于我这个人(请求),
肯德基的服务时间是20分钟。单位是毫秒。
svctm:这个字段会在将来的sysstat安装包中移除。所以不需要关注。(我们的iostat来自于sysstat这个安装包)
%util:没有理解,会查找资料来补充。
关于网络文件系统报告:
NFS客户端会挂载NFS服务端分享的设备,我们可以在NFS客户端上统计我们使用NFS的情况。
Filesystem:指的是网络文件系统。可以用ip:目录或hostname:目录表示。
比如:10.10.10.10:/data/image或者img.example.com:/data/image。
rBlk_nor/s:应用程序通过read()这个系统调用接口,从网络文件系统中读出来的block数,一个block的大小是512字节。
wBlk_nor/s:应用程序通过write()这个系统调用接口,写入到网络文件系统中的block数。
rBlk_dir/s:我们从某个打开的文件中读取的block数。这个文件在网络文件系统中,并且是以O_DIRECT标记打开的。
wBlk_dir/s:我们写入到某个打开的文件中的block数。这个文件在网络文件系统中,并且是以O_DIRECT标记打开的。
rBlk_svr/s:NFS客户端通过NFS READ请求,从服务器读取的block数。
wBlk_svr/s:NFS客户端通过NFS WRITE请求,写入到服务器的block数。
rkB_nor/s:应用程序通过read()这个系统调用接口,从网络文件系统中读出来千字节数。kilobytes。
wkB_nor/s:应用程序通过write()这个系统调用接口,写入到网络文件系统中的千字节数。kilobytes。
rkB_dir/s:我们从某个打开的文件中读取的千字节数。这个文件在网络文件系统中,并且是以O_DIRECT标记打开的。
wkB_dir/s:我们写入到某个打开的文件中的千字节数。这个文件在网络文件系统中,并且是以O_DIRECT标记打开的。
rkB_svr/s:NFS客户端通过NFS READ请求,从服务器读取的千字节数。
wkB_svr/s:NFS客户端通过NFS WRITE请求,写入到服务器的千字节数。
rMB_nor/s:同上,只是改了下单位。
wMB_nor/s:同上,只是改了下单位。
rMB_dir/s:同上,只是改了下单位。
wMB_dir/s:同上,只是改了下单位。
rMB_svr/s:同上,只是改了下单位。
wMB_svr/s:同上,只是改了下单位。
ops/s:每秒向文件系统发起的操作数。
rops/s:每秒向文件系统发起的读操作数。
wops/s:每秒向文件系统发起的写操作数。
总的来说,套路就是:block数,千字节数,兆字节数。
3.命令选项
iostat -c 只显示CPU使用情况
iostat -d 只显示设备使用情况
iostat -n 只显示网络文件系统使用情况
iostat -k 以千字节显示,没有加k时,是以block数显示的
iostat -m 以兆字节显示,没有加m时,是以block数显示的
iostat -N 查看LVM2时比较有用
iostat -j { ID | LABEL | PATH | UUID} [ device | ALL ] 没理解,待查资料。
iostat -p [ { device | ALL } ] 显示块设备的统计信息以及它的分区的统计信息,比如sda块设备和它的分区sda1。
iostat -t 显示每次打印的时间
iostat -V 打印sysstat的版本
iostat -x 展示扩展统计数据,需要参考/proc/diskstat文件和/proc/partions文件
iostat -y 忽略第一次报告(第一次统计数据是从系统启动后算起的),从第二次开始显示
iostat -z 忽略那些在取样期间,没有任何活动的设备统计数据。也就是说,如果设备没有任何写入和读取,那么无须统计它的数据
4.注意事项
/proc文件系统必须要挂载上,iostat才可以工作。
svctm:平均服务时间,这个字段以后将没有意义。因为I/O统计数据是在block层计算的,我们并不知道磁盘驱动器什么时候开始处理一个请求。
5.附加文件
/proc/stat包含系统统计数据。
/proc/uptime包含系统运行时间。
/proc/diskstats包含磁盘统计数据。
/sys包含块设备的统计数据。
/proc/self/mountstats包含网络文件系统的统计数据。
/dev/disk包含持久设备名
6.其余参考命令
sar
pidstat
mpstat
vmstat