centos8平台使用vmstat监控系统
一,vmstat的用途和特点:
vmstat 是一个常用的系统性能分析工具,主要用来分析系统的内存使用情况,也常用来分析 CPU 上下文切换和中断的次数。
相对于 iostat 来说,vmstat 可以同时提供 CPU、内存和 I/O 的使用情况。
说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnblogs.com/architectforest
对应的源码可以访问这里获取: https://github.com/liuhongdi/
说明:作者:刘宏缔 邮箱: 371125307@qq.com
二,vmstat所属的包
1,查看所属的包
[root@blog ~]# whereis vmstat
vmstat: /usr/bin/vmstat /usr/share/man/man8/vmstat.8.gz [root@blog ~]# rpm -qf /usr/bin/vmstat
procps-ng-3.3.15-1.el8.x86_64
2,默认vmstat应该已安装到了centos系统中,
如果找不到命令,可以用yum安装:
[root@blog ~]# yum install procps-ng
三,查看vmstat的版本和帮助
1,查看版本
[root@blog ~]# vmstat --version
vmstat from procps-ng 3.3.15
2,查看帮助
[root@blog ~]# vmstat --help
Usage:
vmstat [options] [delay [count]] Options:
-a, --active active/inactive memory
-f, --forks number of forks since boot
-m, --slabs slabinfo
-n, --one-header do not redisplay header
-s, --stats event counter statistics
-d, --disk disk statistics
-D, --disk-sum summarize disk statistics
-p, --partition <dev> partition specific statistics
-S, --unit <char> define display unit
-w, --wide wide output
-t, --timestamp show timestamp
-h, --help display this help and exit
-V, --version output version information and exit For more details see vmstat(8).
四,例子一:查看默认的输出信息
1,# 每隔5秒输出1组数据
[root@blog ~]# vmstat 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 1435780 2668 13109308 0 0 0 1 1 1 0 0 100 0 0
0 0 0 1435712 2668 13109324 0 0 0 0 1533 1786 0 0 100 0 0
0 0 0 1435712 2668 13109324 0 0 0 0 1562 1826 0 0 100 0 0
2,输出数据的说明:
procs:
r(Running or Runnable):就绪队列的长度,也就是正在运行和等待 CPU 的进程数。
说明:如果等待运行的进程数越多,意味着CPU非常繁忙
b(Blocked):处于不可中断睡眠状态的进程数。意味着被阻塞的进程的数量
system:
cs(context switch)是每秒上下文切换的次数。
in(interrupt)则是每秒中断的次数。
memory:
swpd: 使用的虚拟内存的大小
free: 空闲的物理内存的大小
buff: 用做buffer的内存大小
cache: 用做cache的内存大小
swap
si: 从磁盘交换到内存的交换页数量,单位:KB/秒
Amount of memory swapped in from disk
so: 从内存交换到磁盘的交换页数量,单位:KB/秒
Amount of memory swapped to disk (/s).
io
bi: 每秒从块设备接收到的块数,单位:块/秒 也就是读块设备
Blocks received from a block device (blocks/s).
bo: 每秒发送到块设备的块数,单位:块/秒 也就是写块设备。
Blocks sent to a block device (blocks/s).
cpu:
us: 用户CPU时间(非内核进程占用时间)(单位为百分比)
us的值比较高时,说明用户进程消耗的CPU时间多
sy: 系统使用的CPU时间(单位为百分比)
sy的值高时,说明系统内核消耗的CPU资源多
id: 空闲的CPU的时间(百分比)
wa: 等待IO的CPU时间
wait越大则机器io性能就越差。说明IO等待比较严重
st: 代表当系统运行在虚拟机中的时候,被其他虚拟机占用的 CPU 时间。
Time stolen from a virtual machine
五,例子二:查看活跃和非活跃内存
说明:-a 显示活跃和非活跃内存,所显示的内容除增加inact和active
[root@blog ~]# 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
0 0 0 1426684 10660696 3032584 0 0 0 1 1 1 0 0 100 0 0
输出字段的说明:
inact:表示非活跃内存,也就是不常访问的内存,有可能会被系统回收。
active: 表示活跃内存,也就是最近使用过的内存,一般不会被系统回收。
六,例子三:统计磁盘的读/写信息
说明:-d参数:统计磁盘信息
[root@blog ~]$ vmstat -d
disk- ------------reads------------ ------------writes----------- -----IO------
total merged sectors ms total merged sectors ms cur sec
vda 17722 24 1261334 16251 1699722 146934 54970224 2269699 0 412
vdb 152 0 6576 107 0 0 0 0 0 0
说明:数据来自/proc/diskstats
七,例子四:查看slab信息:
说明:-m参数:统计slab信息
[root@blog ~]# vmstat -m
Cache Num Total Size Pages
nf_conntrack 300 300 320 25
xfs_dqtrx 0 0 528 31
xfs_dquot 0 0 504 16
xfs_rui_item 0 0 696 23
xfs_rud_item 92 92 176 23
xfs_inode 95230 100480 1024 16
xfs_efd_item 198 234 440 18
xfs_buf_item 240 300 272 30
xfs_trans 561 561 232 17 ...
说明:数据来自 /proc/slabinfo
八,例子五:查看内存统计信息:
说明: -s参数:统计内存信息
[sysop@blog ~]$ vmstat -s
15723788 K total memory
1180776 K used memory
3029904 K active memory
10660692 K inactive memory ...
说明:数据来自/proc/meminfo
九,例子六:显示从系统启动至今的fork数量
说明: -f参数:统计fork的数量
[root@blog ~]$ vmstat -f
403762 forks
说明:linux下创建进程的系统调用是fork
十,查看centos版本
[root@blog ~]# cat /etc/redhat-release
CentOS Linux release 8.0.1905 (Core)
centos8平台使用vmstat监控系统的更多相关文章
- centos8平台使用iotop监控磁盘io
一,iotop的作用: iotop是监视磁盘I/O使用状况的top类工具, 可以针对进程和线程统计io的使用情况 说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnblog ...
- centos8平台使用iostat监控磁盘io
一,iostat所属的包: [root@centos8 ~]# whereis iostat iostat: /usr/bin/iostat /usr/share/man/man1/iostat.1. ...
- centos8平台用ss监控网络
一,ss所属的包: [root@blog ~]# whereis ss ss: /usr/sbin/ss /usr/share/man/man8/ss.8.gz [root@blog ~]# rpm ...
- centos8平台使用pidstat监控cpu/内存/io
一,安装pidstat: 1,安装 [root@localhost yum.repos.d]# yum install sysstat 2,查看版本: [root@localhost ~]# pids ...
- centos8平台基于iftop监控网络流量
一,iftop的作用: 基于ip统计外部机器与本机之间的网络流量, 可以方便的查看各客户端是否有非正常的到本机的访问 说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnbl ...
- centos8平台使用mpstat监控cpu
一,mpstat的用途 mpstat是 Multiprocessor Statistics的缩写,是实时cpu监控工具. 在多CPU系统里,其不但能查看所有CPU的平均状况信息,而且能够查看特定CPU ...
- centos8平台使用slabtop监控slab内存的状态
一,slabtop 所属的包: [root@yjweb ~]# whereis slabtop slabtop: /usr/bin/slabtop /usr/share/man/man1/slabto ...
- 【Linux】监控系统的状态
1.w命令 w命令是一个很强大的命令,该命令显示的信息比较丰富.以下是我的虚拟机w命令的一个展示 从上图我们可以看到: 第一行从左面开始显示的信息依次为:时间.系统运行时间.登陆用户数.平均负载 第二 ...
- Legolas工业自动化平台案例 —— 水源地自动化监控系统
天津港爆炸事件后,除了安置群众.追究事故责任外,人们最关心的莫过于爆炸污染物对于周边环境的影响,其中最重要的一块就是饮用水的安全.所幸的是,水源的安全监测是实实在在有据可依的.环保单位和供水企业在建设 ...
随机推荐
- 论文阅读:Relation Structure-Aware Heterogeneous Information Network Embedding
Relation Structure-Aware Heterogeneous Information Network Embedding(RHINE) (AAAI 2019) 本文结构 (1) 解决问 ...
- CTF-Wechall-第三天上午
2020.09.11 奥力给,Wechall这平台不错哦,感觉是一个循序渐近的过程,可能是我是我这么排序的原因吧,hhhhh
- Hadoop入门学习整理(一)
今天是2020年4月8日,是一个平凡而又特殊的日子,武汉在经历了77天的封城之后,于今日0点正式解封.从1月14日放寒假离开武汉,到今天已近3个月,学校的花开了又谢了.随着疫情好转,春回大地,万物复苏 ...
- Knowledge 1:Propositional Logic 命题逻辑基础及符号
Keywords reasoning 推理 Deductive reasoning(for a basic logic) 演绎推理 analogy 类比:比喻 /əˈnælədʒi/ definiti ...
- PyCharm2020.2.1激活方法
本人亲测有效!直接看图! 安装准备 一.百度网盘链接:https://pan.baidu.com/s/151vnrZG2V4eMPW8RYqse3w 提取码:z5k0 至于Pycharm的安装在这 ...
- netty字符串流分包
@Override protected void decode(ChannelHandlerContext channelHandlerContext, ByteBuf in, List<Obj ...
- 我还在生产玩 JDK7,JDK 15 却要来了!
自从 JDK9 之后,每年 3 月与 9 月 JDK 都会发布一个新的版本,而2020 年 9 月即将引来 JDK15. 恰巧 IDEA 每四五个月会升级一个较大的版本,每次升级之后都会支持最新版本 ...
- jwt攻击手段
jwt 秘钥泄漏/敏感文件泄漏 在一些配置文件被我们可查的情况下,包括各种文件读取,源码泄漏,此时伪造身份就变得很容易了. 空加密算法 对于明文的加密算法通常为HS256,在jwt中分为三个部分,以点 ...
- Spark中的聚类算法
Spark - Clustering 官方文档:https://spark.apache.org/docs/2.2.0/ml-clustering.html 这部分介绍MLlib中的聚类算法: 目录: ...
- Android捕捉错误try catch 的简单使用
基本语法 try{ //可能发生错误的程式码 }catch(具体错误 e){ //具体错误有就写,没有就不写,有多个,就写多个catch e.printStackTrace(); //在命令行打印错误 ...