系统性能监控之vmstat和iostat命令
这篇文章主要介绍一些Linux性能检测相关的命令。 vmstat和iostat的两个命令可以运行在主流的Linux/Unix操作系统上。
如果vmstat和iostat命令不能再你的电脑上运行,请安装sysstat包。因为vmstat和iostat命令是集成在SYSSTAT(系统监视工具)包里面。 iostat命令主要生成CPU和所有设备统计报告。你可以下载并安装SYSSTAT,如果使用源代码tar包安装,从这里下载SYSSTAT,但我们建议你使用yum命令安装。
Linux下安装Sysstat
- # yum -y install sysstat
vmstat:搜集内存、进程,paging等信息
iostat:中央处理单元(CPU)的统计数据和设备、分区输入/输出统计信息。
在Linux下6个vmstat命令例子:
1、列出活动和非活动的内存
在下面的示例中,有6列。每列的详细介绍在vmstat的man手册都会有详细解释。最显著的字段是memory下的free,swap下的si以及so。
- [root@tecmint ~]# vmstat -a
- procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
- r b swpd free inact active si so bi bo in cs us sy id wa st
- 1 0 0 810420 97380 70628 0 0 115 4 89 79 1 6 90 3 0
A、free : 空闲的空间。
B、si : 从磁盘到Swap的速度是千字节每秒。
C、so :从Swape到磁盘的速度是千字节每秒。
注意:如果您运行vmstat不带参数,它缺省会显示汇总报告。
2、每隔’X'秒执行vmstat一次(N为执行的次数)
使用此命令,执行的vmstat每隔2秒钟执行一次,执行6次后自动停止。
- [root@tecmint ~]# vmstat 2 6
- procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
- r b swpd free buff cache si so bi bo in cs us sy id wa st
- 0 0 0 810420 22064 101368 0 0 56 3 50 57 0 3 95 2 0
- 0 0 0 810412 22064 101368 0 0 0 0 16 35 0 0 100 0 0
- 0 0 0 810412 22064 101368 0 0 0 0 14 35 0 0 100 0 0
- 0 0 0 810412 22064 101368 0 0 0 0 17 38 0 0 100 0 0
- 0 0 0 810412 22064 101368 0 0 0 0 17 35 0 0 100 0 0
- 0 0 0 810412 22064 101368 0 0 0 0 18 36 0 1 100 0 0
3、vmstat命令带时间戳
vmstat命令使用-t参数显示时间戳,如下图所示的每一行都会记录。
- [tecmint@tecmint ~]$ vmstat -t 1 5
- procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------ ---timestamp---
- r b swpd free buff cache si so bi bo in cs us sy id wa st
- 0 0 0 632028 24992 192244 0 0 70 5 55 78 1 3 95 1 0 2012-09-02 14:57:18 IST
- 1 0 0 632028 24992 192244 0 0 0 0 171 514 1 5 94 0 0 2012-09-02 14:57:19 IST
- 1 0 0 631904 24992 192244 0 0 0 0 195 600 0 5 95 0 0 2012-09-02 14:57:20 IST
- 0 0 0 631780 24992 192244 0 0 0 0 156 524 0 5 95 0 0 2012-09-02 14:57:21 IST
- 1 0 0 631656 24992 192244 0 0 0 0 189 592 0 5 95 0 0 2012-09-02 14:57:22 IST
4、各种计数器的统计信息
用vmstat -s参数来显示各种事件计数器和内存统计信息。
- [tecmint@tecmint ~]$ vmstat -s
- 1030800 total memory
- 524656 used memory
- 277784 active memory
- 185920 inactive memory
- 506144 free memory
- 26864 buffer memory
- 310104 swap cache
- 2064376 total swap
- 0 used swap
- 2064376 free swap
- 4539 non-nice user cpu ticks
- 0 nice user cpu ticks
- 11569 system cpu ticks
- 329608 idle cpu ticks
- 5012 IO-wait cpu ticks
- 79 IRQ cpu ticks
- 74 softirq cpu ticks
- 0 stolen cpu ticks
- 336038 pages paged in
- 67945 pages paged out
- 0 pages swapped in
- 0 pages swapped out
- 258526 interrupts
- 392439 CPU context switches
- 1346574857 boot time
- 2309 forks
5、磁盘统计
用vmstat的-d选项显示所有磁盘的统计数据。
- [tecmint@tecmint ~]$ vmstat -d
- disk- ------------reads------------ ------------writes----------- -----IO------
- total merged sectors ms total merged sectors ms cur sec
- ram0 0 0 0 0 0 0 0 0 0 0
- ram1 0 0 0 0 0 0 0 0 0 0
- ram2 0 0 0 0 0 0 0 0 0 0
- ram3 0 0 0 0 0 0 0 0 0 0
- ram4 0 0 0 0 0 0 0 0 0 0
- ram5 0 0 0 0 0 0 0 0 0 0
- ram6 0 0 0 0 0 0 0 0 0 0
- ram7 0 0 0 0 0 0 0 0 0 0
- ram8 0 0 0 0 0 0 0 0 0 0
- ram9 0 0 0 0 0 0 0 0 0 0
- ram10 0 0 0 0 0 0 0 0 0 0
- ram11 0 0 0 0 0 0 0 0 0 0
- ram12 0 0 0 0 0 0 0 0 0 0
- ram13 0 0 0 0 0 0 0 0 0 0
- ram14 0 0 0 0 0 0 0 0 0 0
- ram15 0 0 0 0 0 0 0 0 0 0
- loop0 0 0 0 0 0 0 0 0 0 0
- loop1 0 0 0 0 0 0 0 0 0 0
- loop2 0 0 0 0 0 0 0 0 0 0
- loop3 0 0 0 0 0 0 0 0 0 0
- loop4 0 0 0 0 0 0 0 0 0 0
- loop5 0 0 0 0 0 0 0 0 0 0
- loop6 0 0 0 0 0 0 0 0 0 0
- loop7 0 0 0 0 0 0 0 0 0 0
- sr0 0 0 0 0 0 0 0 0 0 0
- sda 7712 5145 668732 409619 3282 28884 257402 644566 0 126
- dm-0 11578 0 659242 1113017 32163 0 257384 8460026 0 126
- dm-1 324 0 2592 3845 0 0 0 0 0 2
6、统计显示以MB为单位
vmstat以兆为单位显示,用参数-S和M(大写)。参数-S对应的值可以是k, K, m or M (默认为 kb)
- [root@tecmint ~]# vmstat -S M 1 5
- procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
- r b swpd free buff cache si so bi bo in cs us sy id wa st
- 0 0 0 346 53 476 0 0 95 8 42 55 0 2 96 2 0
- 0 0 0 346 53 476 0 0 0 0 12 15 0 0 100 0 0
- 0 0 0 346 53 476 0 0 0 0 32 62 0 0 100 0 0
- 0 0 0 346 53 476 0 0 0 0 15 13 0 0 100 0 0
- 0 0 0 346 53 476 0 0 0 0 34 61 0 1 99 0 0
在Linux下6个iostat命令例子
7、显示CPU和I/O统计信息
iostat的不带参数的显示CPU和I/ O的所有分区的统计信息,如下图所示。
- [root@tecmint ~]# iostat
- Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012 _i686_ (1 CPU)
- avg-cpu: %user %nice %system %iowait %steal %idle
- 0.12 0.01 1.54 2.08 0.00 96.24
- Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
- sda 3.59 161.02 13.48 1086002 90882
- dm-0 5.76 159.71 13.47 1077154 90864
- dm-1 0.05 0.38 0.00 2576 0
8、只显示CPU的统计信息
用iostat的-c参数,如下图所示只显示CPU统计信息。
- [root@tecmint ~]# iostat -c
- Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012 _i686_ (1 CPU)
- avg-cpu: %user %nice %system %iowait %steal %idle
- 0.12 0.01 1.47 1.98 0.00 96.42
9、只显示磁盘的I/O统计
用iostat的-D参数显示只有I/O的所有分区的统计数据。
- [root@tecmint ~]# iostat -d
- Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012 _i686_ (1 CPU)
- Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
- sda 3.35 149.81 12.66 1086002 91746
- dm-0 5.37 148.59 12.65 1077154 91728
- dm-1 0.04 0.36 0.00 2576 0
10、只显示单一设备的I/O统计信息。
默认情况下,它会显示所有分区的统计信息,使用-p和设备名称参数只显示只显示磁盘用于特定设备的I/O统计信息。
- [root@tecmint ~]# iostat -p sda
- Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012 _i686_ (1 CPU)
- avg-cpu: %user %nice %system %iowait %steal %idle
- 0.11 0.01 1.44 1.92 0.00 96.52
- Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
- sda 3.32 148.52 12.55 1086002 91770
- sda1 0.07 0.56 0.00 4120 18
- sda2 3.22 147.79 12.55 1080650 91752
11、显示LVM统计
使用-n(大写)参数只显示LVM的统计数据,如图所示。
- [root@tecmint ~]# iostat -N
- Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012 _i686_ (1 CPU)
- avg-cpu: %user %nice %system %iowait %steal %idle
- 0.11 0.01 1.39 1.85 0.00 96.64
- Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
- sda 3.20 142.84 12.16 1086002 92466
- vg_tecmint-lv_root 5.13 141.68 12.16 1077154 92448
- vg_tecmint-lv_swap 0.04 0.34 0.00 2576 0
12、iostat的版本。
与-V(大写)参数显示iostat的版本,如下所示。
- [root@tecmint ~]# iostat -V
- sysstat version 9.0.4
(C) Sebastien Godard (sysstat orange.fr)
注:vmstat和iostat的包含列和标志可能不能详细解释。
系统性能监控之vmstat和iostat命令的更多相关文章
- 使用vmstat和iostat命令进行Linux性能监控【转】
转自:https://linux.cn/article-4024-1.html 这是我们正在进行的Linux命令和性能监控系列的一部分.vmstat和iostat两个命令都适用于所有主要的类unix系 ...
- vmstat和iostat命令进行Linux性能监控
这是我们正在进行的Linux命令和性能监控系列的一部分.vmstat和iostat两个命令都适用于所有主要的类unix系统(Linux/unix/FreeBSD/Solaris). 如果vmstat和 ...
- Linux系统性能监控之6个vmstat和6个iostat命令
这篇文章主要介绍一些Linux性能检测相关的命令. vmstat和iostat的两个命令可以运行在主流的Linux/Unix操作系统上. 如果vmstat和iostat命令不能再你的电脑上运行,请安装 ...
- Linux 系统性能监控命令详解
Linux 系统性能监控命令详解 CPU MEMORY IO NETWORK LINUX进程内存占用查看方法 系统负载过重时往往会引起其它子系统的问题,比如:->大量的读入内存的IO请求(pag ...
- vmstat/top/iostat/route/sar 常用命令
[vmstat]Virtual Meomory Statistics(虚拟内存统计)的缩写,可对操作系统的虚拟内存.进程.CPU活动进行监控.是对系统的整体情况进行统计,不足之处是无法对某个进程进行深 ...
- iostat、vmstat、iftop命令详解
1.安装iostat命令 yum install sysstat -y 用法:iostat [ 选项 ] [ <时间间隔> [ <次数> ]] 常用选项说明: -c:只显示系统 ...
- zabbix使用iostat命令参数监控磁盘性能
iostat命令 先说一个坑把,在开始监控的时候使用命令iostat -dtkx,得到的结果看上去没问题,但是在web监控窗口数据就说不变动,为啥呢,因为iostat这个命令得到的第一个数据始终是磁盘 ...
- iostat命令——监控系统设备的IO负载情况
iostat命令的安装 #yum install sysstat iostat常见选项 -t 输出数据时打印搜集数据的时间 -m 输出的数据以MB为单位 -d 显示磁盘的统计信息 # iost ...
- linux 操作系统级别监控 iostat 命令
iostat命令可以查看当前机器磁盘io的数据 命令:iostat -x -k 1 -x:展示磁盘的扩展信息 -k:以k为单位展示磁盘数据 1:每1秒刷新一次 展示结果 util:磁盘IO使用率,单位 ...
随机推荐
- [SQL Server系] -- 视图
1:定义 从用户角度来看,一个视图是从一个特定的角度来查看数据库中的数据. 从数据库系统内部来看,一个视图是由SELECT语句组成的查询定义的虚拟表. 从数据库系统内部来看,视图是由一张或多张表中的数 ...
- dynamic介绍
Visual C# 2010 引入了一个新类型 dynamic. 该类型是一种静态类型,但类型为 dynamic 的对象会跳过静态类型检查. 大多数情况下,该对象就像具有类型 object 一样. 在 ...
- linux入门教程(八) Linux磁盘管理
[查看磁盘或者目录的容量 df 和 du] df 查看已挂载磁盘的总容量.使用容量.剩余容量等,可以不加任何参数,默认是按k为单位显示的 df常用参数有 –i -h -k –m等 -i 使用inode ...
- lintcode :Reverse Words in a String 翻转字符串
题目: 翻转字符串 给定一个字符串,逐个翻转字符串中的每个单词. 样例 给出s = "the sky is blue",返回"blue is sky the" ...
- Unity UGUI —— 无限循环List(转载)
using UnityEngine; using System.Collections; using System.Collections.Generic; using UnityEngine.UI; ...
- Apache 下SVN项目管理使用说明
Apache 下SVN项目管理使用说明 (1)Apaceh和SVN先要装好. (2)在apache的目录下找到httpd.conf文件,在最后一行增加如下配置 Include conf/svn.pro ...
- JCIFS读取远程服务器文件过慢的解决方法
JCIFS读取远程服务器文件过慢的解决方法 发表于3年前(2013-07-12 11:23) 阅读(1174) | 评论(0) // 我要收藏"; var favor_del = &qu ...
- 增加oracle数据库最大连接数
这几天碰到系统不能登陆的情况,初步判断可能是数据库连接满了,(后来检查不是这个原因),做了一次增加数据库最大连接数操作.操作步骤如下 操作系统:Red Hat Enterprise Linux Ser ...
- laravel Restful
参考:http://www.cnblogs.com/youxin/p/3967274.html http://scotch.io/tutorials/simple-laravel-crud-with- ...
- 即时通信Spark安装和配置
spark:Cross-platform real-time collaboration client optimized for business and organizations.Spark i ...