`
wx1569578408
  • 浏览: 71486 次
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

性能排查 -- vmstat 使用

 
阅读更多

vmstat命令是最常见的Linux/Unix监控工具,可以展现给定时间间隔的服务器的状态值,包括服务器的CPU使用率,内存使用,虚拟内存交换情况,IO读写情况。这个命令是我查看Linux/Unix最喜爱的命令,一个是Linux/Unix都支持,二是相比top,我可以看到整个机器的CPU,内存,IO的使用情况,而不是单单看到各个进程的CPU使用率和内存使用率(使用场景不一样)。

一般vmstat工具的使用是通过两个数字参数来完成的,第一个参数是采样的时间间隔数,单位是秒,第二个参数是采样的次数,如:

root@ubuntu:~# vmstat 2 1
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
 1  0      0 3498472 315836 3819540    0    0     0     1    2    0  0  0 100  0

2表示每个两秒采集一次服务器状态,1表示只采集一次。

实际上,在应用过程中,我们会在一段时间内一直监控,不想监控直接结束vmstat就行了,例如:

复制代码

root@ubuntu:~# vmstat 2  
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
 1  0      0 3499840 315836 3819660    0    0     0     1    2    0  0  0 100  0
 0  0      0 3499584 315836 3819660    0    0     0     0   88  158  0  0 100  0
 0  0      0 3499708 315836 3819660    0    0     0     2   86  162  0  0 100  0
 0  0      0 3499708 315836 3819660    0    0     0    10   81  151  0  0 100  0
 1  0      0 3499732 315836 3819660    0    0     0     2   83  154  0  0 100  0

复制代码

这表示vmstat每2秒采集数据,一直采集,直到我结束程序,这里采集了5次数据我就结束了程序。

好了,命令介绍完毕,现在开始实战讲解每个参数的意思。

r 表示运行队列(就是说多少个进程真的分配到CPU),我测试的服务器目前CPU比较空闲,没什么程序在跑,当这个值超过了CPU数目,就会出现CPU瓶颈了。这个也和top的负载有关系,一般负载超过了3就比较高,超过了5就高,超过了10就不正常了,服务器的状态很危险。top的负载类似每秒的运行队列。如果运行队列过大,表示你的CPU很繁忙,一般会造成CPU使用率很高。

b 表示阻塞的进程,这个不多说,进程阻塞,大家懂的。

swpd 虚拟内存已使用的大小,如果大于0,表示你的机器物理内存不足了,如果不是程序内存泄露的原因,那么你该升级内存了或者把耗内存的任务迁移到其他机器。

free   空闲的物理内存的大小,我的机器内存总共8G,剩余3415M。

buff   Linux/Unix系统是用来存储,目录里面有什么内容,权限等的缓存,我本机大概占用300多M

cache cache直接用来记忆我们打开的文件,给文件做缓冲,我本机大概占用300多M(这里是Linux/Unix的聪明之处,把空闲的物理内存的一部分拿来做文件和目录的缓存,是为了提高 程序执行的性能,当程序使用内存时,buffer/cached会很快地被使用。)

si  每秒从磁盘读入虚拟内存的大小,如果这个值大于0,表示物理内存不够用或者内存泄露了,要查找耗内存进程解决掉。我的机器内存充裕,一切正常。

so  每秒虚拟内存写入磁盘的大小,如果这个值大于0,同上。

bi  块设备每秒接收的块数量,这里的块设备是指系统上所有的磁盘和其他块设备,默认块大小是1024byte,我本机上没什么IO操作,所以一直是0,但是我曾在处理拷贝大量数据(2-3T)的机器上看过可以达到140000/s,磁盘写入速度差不多140M每秒

bo 块设备每秒发送的块数量,例如我们读取文件,bo就要大于0。bi和bo一般都要接近0,不然就是IO过于频繁,需要调整。

 

bi: Blocks received from a block device (blocks/s).——每秒从块设备接收到的块数,即读块设备。
bo: Blocks sent to a block device (blocks/s).——每秒发送到块设备的块数,即写块设备。

 

 

in 每秒CPU的中断次数,包括时间中断

cs 每秒上下文切换次数,例如我们调用系统函数,就要进行上下文切换,线程的切换,也要进程上下文切换,这个值要越小越好,太大了,要考虑调低线程或者进程的数目,例如在apache和nginx这种web服务器中,我们一般做性能测试时会进行几千并发甚至几万并发的测试,选择web服务器的进程可以由进程或者线程的峰值一直下调,压测,直到cs到一个比较小的值,这个进程和线程数就是比较合适的值了。系统调用也是,每次调用系统函数,我们的代码就会进入内核空间,导致上下文切换,这个是很耗资源,也要尽量避免频繁调用系统函数。上下文切换次数过多表示你的CPU大部分浪费在上下文切换,导致CPU干正经事的时间少了,CPU没有充分利用,是不可取的。

us 用户CPU时间,我曾经在一个做加密解密很频繁的服务器上,可以看到us接近100,r运行队列达到80(机器在做压力测试,性能表现不佳)。

sy 系统CPU时间,如果太高,表示系统调用时间长,例如是IO操作频繁。

id  空闲 CPU时间,一般来说,id + us + sy = 100,一般我认为id是空闲CPU使用率,us是用户CPU使用率,sy是系统CPU使用率。

wt 等待IO CPU时间。

转载于:https://my.oschina.net/u/923508/blog/735594

分享到:
评论

相关推荐

    线上问题排查-Linux 性能观测篇.pdf

    总结来说,Linux性能观测需要系统管理员和架构师对操作系统的内核机制有深入的理解,并且熟悉性能分析工具的使用,如top, vmstat, iostat, mpstat等。这些工具能够提供关于CPU、内存、I/O和网络等方面的详细性能数据...

    Linux系统cpu,内存高负载排查-云主机-产品文档-帮助文档-京东云.pdf

    在进行系统排查时,除了`top`命令,还可以使用`htop`(一个增强版的`top`)、`vmstat`(虚拟内存统计)和`iostat`(I/O统计)等工具来获取更详细的系统资源使用情况。例如,`vmstat`可以查看内存和交换空间的使用,...

    sysstat.rar

    在运维工作中,了解和掌握sysstat对于优化系统性能、排查问题具有重要的价值。 sysstat的核心组件包括sar(System Activity Report)、iostat(Input/Output Statistics)、mpstat(Multi-Processor Statistics)和...

    vmstat结果内容的解释

    它能够提供系统当前的虚拟内存状态、进程情况、CPU使用率、磁盘I/O活动等关键信息,是系统管理员进行故障排查和性能调优的重要工具之一。下面,我们将对`vmstat`的输出结果进行详细解读,帮助理解和掌握其各项指标的...

    Linux性能分析之CPU实战-视频课程资源网盘链接提取码下载 .txt

    - 与CPU性能相关的故障排查技巧 #### 三、实践操作指南 - **实战步骤一**:安装并配置必要的性能分析工具。 - **实战步骤二**:模拟不同的CPU负载场景,如运行高并发服务或执行计算密集型任务。 - **实战步骤三**...

    linux中vmstat的使用.docx

    `vmstat`是一款功能强大的Linux系统性能监控工具,能够提供系统级别的多种性能指标,包括但不限于进程状态、内存使用情况、虚拟内存交换、磁盘I/O活动、系统中断、上下文切换以及CPU使用率等方面的信息。这些数据...

    vmstat 命令详解

    - **故障排查**:在遇到系统响应慢或崩溃等问题时,通过分析 `vmstat` 的输出数据,可以帮助定位问题所在。 #### 六、总结 `vmstat` 是一个非常强大的系统监控工具,它提供了丰富的性能指标数据,对于深入理解...

    linux典型案例分析.docx

    linux 在Linux系统中,有许多典型的案例分析,涵盖了从系统性能优化、安全问题排查,到内核调试和网络配置等方面的内容。以下是几个常见的Linux典型案例分析: 1. 系统性能优化案例 背景: 某生产服务器经常出现...

    Linux系统问题排查

    - 使用`vmstat`或`sar`命令查看CPU的详细统计信息,如user、sys、iowait等。 - 使用`mpstat`和`perf`等工具深入分析CPU使用细节。 - **解决方案**: - 如果用户进程使用率高,考虑弹性扩容。 - 如果I/O等待高,...

    liunx后台vmstat命令

    Linux/Unix 系统管理员在监控系统性能时,经常会使用 `vmstat` 命令。这个命令提供了关于操作系统核心层面的关键信息,包括CPU、内存、虚拟内存交换、输入输出(I/O)活动以及系统调度等状态。下面我们将深入探讨 `...

    性能分析与故障诊断.ppt

    - **一般性能分析过程**:通常包括识别性能瓶颈,例如CPU利用率、内存使用情况、I/O负载和网络性能。通过监控这些指标,可以判断系统是否在正常运行。 - **性能分析工具**: - **vmstat**:提供关于虚拟内存、...

    HP性能故障HP性能故障

    2. **故障排查工具**:使用一系列工具和技术,包括基本Unix工具(如sar、vmstat等)、Performance Advisor套件、Glance、GPM等,帮助定位和解决具体的性能故障。 3. **深入分析**:对于难以诊断的问题,可以使用更...

    linux服务器故障排查

    - `vmstat`、`iostat`和`mpstat`用于详细分析系统的性能瓶颈。 3. **服务状态检查**: - 使用`systemctl status`或`service`命令检查服务是否正常运行。 - 对于Apache、MySQL等服务,可以查看它们的专用日志文件...

    性能测试常见的问题及解决方案

    - 通过`vmstat`实时监控CPU使用情况,如果AP CPU超过60%的指标,需进行分析。 - 区分use CPU和sys CPU,如果是use CPU过高,通常意味着应用程序消耗过多CPU资源。 - 使用`top`命令找出消耗CPU最多的进程,然后...

    高性能Linux服务器构建实战 系统安全、故障排查、自动化运维与集群架构

    本书将介绍如何通过日志分析、性能监控工具(如top、vmstat、iostat、netstat等)定位和解决各种系统问题,如CPU过载、内存泄漏、磁盘I/O瓶颈等。同时,还会讲述如何处理网络故障、服务异常等问题,以确保系统的正常...

    《aix5.3 性能管理指南》

    根据提供的信息,《AIX5.3性能管理指南》是一份针对IBM AIX 5.3操作系统性能管理和优化的...同时,面对复杂多变的性能问题时,还需要具备一定的故障排查能力和实践经验,以便快速准确地定位问题所在并采取相应措施。

    AIX日常维护命令

    - 使用 `vmstat 2 10` 监控内存使用率。 - 使用 `ps aux` 查看所有进程的内存使用情况。 - 使用 `svmon -G` 获取内存的详细信息。 - 使用 `svmon -P au 10` 显示每个进程的内存占用情况。 3. **监视 I/O 使用...

    线上问题排查

    在 Linux 环境下,线上问题排查往往依赖于对系统资源使用的监控,包括 CPU、内存、磁盘 I/O 等关键性能指标的实时分析。下面详细介绍这些工具及其对应的性能指标。 ##### 1. CPU 相关指标 - **基本概念** - **上...

    Java线上故障排查方案(2).pdf

    比如,使用top或htop命令查看实时的系统状态,使用vmstat、iostat等命令来检查内存和I/O性能,以及使用netstat检查网络连接状态等。 Arthas是一个Java诊断工具,其提供了丰富的命令用于对Java应用进行问题诊断。...

    AIX_性能调整及维护案例2011.pdf

    **1.2 AIX5L 内存性能优化之使用 ps、sar、svmon 和 vmstat 监视内存的使用** 这一部分深入探讨了如何使用 `ps`、`sar`、`svmon` 和 `vmstat` 这些工具来监控 AIX 5.3 系统的内存使用情况。通过对这些工具的输出...

Global site tag (gtag.js) - Google Analytics