首页 > 其他分享 >vmstat的使用

vmstat的使用

时间:2024-11-14 15:45:49浏览次数:1  
标签:每秒 vmstat 内存 IO 使用 磁盘 CPU

1.用法 vmstat [-a] [-n] [-S unit] [delay [ count]] vmstat [-s] [-n] [-S unit] vmstat [-m] [-n] [delay [ count]] vmstat [-d] [-n] [delay [ count]] vmstat [-p disk partition] [-n] [delay [ count]] vmstat [-f] vmstat [-V]

-a:显示活跃和非活跃内存

-f:显示从系统启动至今的 fork 数量 。

-m:显示 slabinfo

-n:只在开始时显示一次各字段名称。

-s:显示内存相关统计信息及多种系统活动数量。

delay:刷新时间间隔。如果不指定,只显示一条结果。

count:刷新次数。如果不指定刷新次数,但指定了刷新时间间隔,这时刷新次数为无穷。

-d:显示磁盘相关统计信息。

-p:显示指定磁盘分区统计信息

-S:使用指定单位显示。参数有 k 、K 、m 、M ,分别代表 1000、1024、1000000、1048576 字节(byte)。 默认单位为 K(1024 bytes)

-V:显示 vmstat 版本信息。 

例子:

字段说明: Procs(进程): r: 运行的和等待(CPU 时间片)运行的进程数,这个值也可以判断是否需要增加 CPU(长期大于 1) b: 等待 IO 的进程数量,处于不可中断状态的进程数,常见的情况是由 IO 引起的 Memory(内存): swpd: 使用虚拟内存大小,切换到交换内存上的内存(默认以 KB 为单位) 如果 swpd 的值不为 0,或者还比较大,比如超过 100M 了,但是 si, so 的值长期为 0,这种情况我 们可以不用担心,不会影响系统性能。 free: 空闲的物理内存 buff: 用作缓冲的内存大小 cache: 用作缓存的内存大小,文件系统的 cache,如果 cache 的值大的时候,说明 cache 住的文件数 多,如果频繁访问到的文件都能被 cache 住,那么磁盘的读 IO bi 会非常小 Swap: si: 每秒从交换区写到内存的大小,交换内存使用,由磁盘调入内存 so: 每秒写入交换区的内存大小,交换内存使用,由内存调入磁盘 内存够用的时候,这 2 个值都是 0,如果这 2 个值长期大于 0 时,系统性能会受到影响。磁盘 IO 和 CPU 资源都会被消耗。 常有人看到空闲内存(free)很少或接近于 0 时,就认为内存不够用了,实际上不能光看这一点的,还 要结合 si,so,如果 free 很少,但是 si,so 也很少(大多时候是 0),那么不用担心,系统性能这时不会受 到影响的。 IO:(现在的 Linux 版本块的大小为 1024bytes) bi: 每秒读取的块数,从块设备读入的数据总量(读磁盘) (KB/s) bo: 每秒写入的块数,写入到块设备的数据总理(写磁盘) (KB/s) 随机磁盘读写的时候,这 2 个值越大(如超出 1M),能看到 CPU 在 IO 等待的值也会越大 system: in: 每秒中断数,包括时钟中断。 cs: 每秒上下文切换数。 上面这 2 个值越大,会看到由内核消耗的 CPU 时间会越多 CPU(以百分比表示): us: 用户进程消耗的 CPU 时间百分比,us 的值比较高时,说明用户进程消耗的 CPU 时间多,但是如 果长期超过 50% 的使用,那么我们就该考虑优化程序算法或者进行加速了 sy: 内核进程消耗的 CPU 时间百分比,sy 的值高时,说明系统内核消耗的 CPU 资源多,这并不是良 性的表现,我们应该检查原因。 id: CPU 处在空闲状态时间百分比(包括 IO 等待时间) wa: IO 等待消耗的 CPU 时间百分比,wa 的值高时,说明 IO 等待比较严重,这可能是由于磁盘大量 作随机访问造成,也有可能是磁盘的带宽出现瓶颈(块操作)。

显示活跃和非活跃内存 

使用-a 选项显示活跃和非活跃内存时,所显示的内容除增加 inact 和 active 外,其他显示内容与例子 1 相同。 字段说明: Memory(内存): inact: 非活跃内存大小(当使用-a 选项时显示) active: 活跃的内存大小(当使用-a 选项时显示) 注:如果 r 经常大于 4,且 id 经常少于 40,表示 cpu 的负荷很重,如果 bi,bo 长期不等于 0,表示内 存不足,如果 disk 经常不等于 0,且在 b 中的队列大于 3,表示 io 性能不好。 CPU 问题现象: 1.)如果在processes中运行的序列(process r)是连续的大于在系统中的CPU的个数表示系统现在运行比较 慢,有多数的进程等待 CPU. 2.)如果 r 的输出数大于系统中可用 CPU 个数的 4 倍的话,则系统面临着 CPU 短缺的问题,或者是 CPU 的速 率过低,系统中有多数的进程在等待 CPU,造成系统中进程运行过慢. 3.)如果空闲时间(cpu id)持续为 0 并且系统时间(cpu sy)是用户时间的两倍(cpu us)系统则面临着 CPU 资源 的短缺. 解决办法: 当发生以上问题的时候请先调整应用程序对 CPU 的占用情况.使得应用程序能够更有效的使用 CPU.同 时可以考虑增加更多的 CPU. 关于 CPU 的使用情况还可以结合 mpstat, ps aux top prstat –a 等 等一些相应的命令来综合考虑关于具体的CPU的使用情况,和那些进程在占用大量的CPU时间.一般情 况下,应用程序的问题会比较大一些.比如一些 SQL 语句不合理等等都会造成这样的现象. 内存问题现象: 内存的瓶颈是由 scan rate (sr)来决定的.scan rate 是通过每秒的始终算法来进行页扫描的.如果 scan rate(sr)连续的大于每秒 200 页则表示可能存在内存缺陷.同样的如果 page 项中的 pi 和 po 这两栏表示每 秒页面的调入的页数和每秒调出的页数.如果该值经常为非零值,也有可能存在内存的瓶颈,当然,如果个 别的时候不为 0 的话,属于正常的页面调度这个是虚拟内存的主要原理. 解决办法: 1.调节 applications & servers 使得对内存和 cache 的使用更加有效. 2.增加系统的内存. 3. Implement priority paging in s in pre solaris 8 versions by adding line "set priority paging=1" in /etc/system. Remove this line if upgrading from Solaris 7 to 8 & retaining old /etc/system file. 关于内存的使用情况还可以结 ps aux top prstat –a 等等一些相应的命令来综合考虑关于具体的内 存的使用情况,和那些进程在占用大量的内存.一般情况下,如果内存的占用率比较高,但是,CPU 的占用 很低的时候,可以考虑是有很多的应用程序占用了内存没有释放,但是,并没有占用 CPU 时间,可以考虑 应用程序,对于未占用 CPU 时间和一些后台的程序,释放内存的占用

标签:每秒,vmstat,内存,IO,使用,磁盘,CPU
From: https://www.cnblogs.com/xxllx/p/18546194

相关文章

  • 使用Java爬虫技术高效获取电商平台店铺商品数据
    在电商领域,商品信息的获取是进行市场分析、竞品监控等工作的基础。本文将介绍如何利用Java爬虫技术,通过API接口高效地获取店铺所有商品的详细信息。我们将使用Java语言,结合HttpClient库和JSON解析库,展示从API请求数据到数据处理的整个过程。理解API接口API(应用程序编程接口)允......
  • 切面同时使用@Pointcut 和 @Around 跟单独使用有什么区别
    同时使用@Pointcut和@Around与单独使用@Around的主要区别在于代码的复用性和可读性。下面详细解释这两种方式的区别:1.单独使用 @Around当你直接在@Around注解中定义切点表达式时,切点表达式会内联在每个@Around方法中。这种方式简单直接,但可能会导致代码重复和维......
  • [QT][NCNN][YOLOV8-SEG]使用ncnn框架部署yolov8-seg,外加qt进行界面可视化操作,用于图片
    yolov8seg_qt_ncnn使用ncnn框架部署yolov8-seg,外加qt进行界面可视化操作,用于图片和视频实例分割推理。Github地址:https://github.com/zhahoi/yolov8seg_qt_ncnn起一直以来自己做算法部署或者是模型推理,最后总是需要在命令行敲各种命令,然后通常借助opencv进行可视化。老......
  • 丹摩征文活动|丹摩智算平台使用指南
    目录1.登录平台与工作环境设置1.1访问与登录1.2创建或选择项目1.3初始化项目环境2.数据上传与管理2.1数据上传2.2数据管理与预处理2.3数据可视化3.模型构建与训练3.1模型选择3.2参数配置3.3模型训练与评估4.模型部署与应用4.1模型部署4.2接口调用与集......
  • 解决 uniapp打包app 使用uview的图片上传导致的 您的应用在运行时,未同步告知权限申请
    该问题主要原因是因为u-upload的组件在点击上传组件就直接触发了权限获取而华为的要求是点击拍摄提示获取相机权限并提示点击从相册选择获取存储权限并提示本文主要解决uview的u-upload导致的问题解决思路为修改u-upload组件在u-upload组件添加以下代码//自定义......
  • 【Pytorch】神经网络介绍|激活函数|使用pytorch搭建方法
    神经网络神经网络介绍概念神经网络人工神经网络ANN也称神经网络NN是一种模仿生物神经网络结构和功能的计算模型人脑可以看作是一个生物神经网络,由众多神经元连接而成,神经网络可以看作是模拟生物神经元的过程输入层inputLayer:输入x的那一层输出层output......
  • Jmeter (5.6.3) Windows 使用示例
    步骤:1.下载apache-jmeter-5.6.3.zip2.解压,在环境变量Path中,新增jMeter的bin文件夹的路径3.在bin文件夹中,双击jmeter.bat->打开JMeter4.在JMeter的窗口中:文件->新建(创建测试计划)5.测试计划右键:添加->线程(用户)->线程组6.线程组右键:添加->取样器->HTTP请求7.HTTP请......
  • 使用 Infinispan 缓存功能支持多个 Redis 数据库
    使用Infinispan缓存功能支持多个Redis数据库    在Infinispan15中,我们提供了大量命令,可以在不更改代码的情况下将Redis服务器替换为Infinispan。在本教程中,您将了解Infinispan缓存别名如何帮助您将多个Redis数据库的Redis服务器替换为Infinispan关键要点:什......
  • 如果在整个项目中 QTcpSocket 被多次引用,并且多个对象或类需要共享同一个 QTcpSocket
    如果在整个项目中QTcpSocket被多次引用,并且多个对象或类需要共享同一个QTcpSocket实例,那么使用QSharedPointer<QTcpSocket>是一个不错的选择。以下是使用QSharedPointer<QTcpSocket>的优点、注意事项以及一些替代方案的建议。为什么推荐使用QSharedPointer<QTcpSo......
  • 使用 Python 和 OpenCV 实现摄像头人脸检测并截图
    概述在现代应用中,人脸检测是一项非常重要的技术,广泛应用于安全监控、身份验证等领域。本文将详细介绍如何使用Python和OpenCV库实现摄像头人脸检测并截图,并通过具体的代码示例来展示整个过程。环境准备在开始编写代码之前,确保已经安装了OpenCV库。可以使用以下命令......