Centos7查看磁盘和CUP统计信息iostat命令

Centos7查看磁盘和CUP统计信息iostat命令

Centos7内存高|查看占用内存命令

docker实战(一):centos7 yum安装docker

docker实战(二):基础命令篇

docker实战(三):docker网络模式(超详细)

docker实战(四):docker架构原理

docker实战(五):docker镜像及仓库配置

docker实战(六):docker 网络及数据卷设置

docker实战(七):docker 性质及版本选择

认知升维: 道、法、术、器、势


一: Centos7 查看磁盘i/o, 定位占用i/o读写高的进程

  • iostat 主要用于输出磁盘IO 和 CPU的统计信息。

  • iostat属于sysstat软件包。可以用yum install sysstat 直接安装。


1、iostat 用法

用法:iostat [选项] [<时间间隔>] [<次数>]

命令参数:
-c: 显示CPU使用情况
-d: 显示磁盘使用情况
-N: 显示磁盘阵列(LVM) 信息
-n: 显示NFS 使用情况
-k: 以 KB 为单位显示
-m: 以 M 为单位显示
-t: 报告每秒向终端读取和写入的字符数和CPU的信息
-V: 显示版本信息
-x: 显示详细信息
-p:[磁盘] 显示磁盘和分区的情况

2、先用iostat查看磁盘io 是否读写负载很高

用iostat -d -k -x 1 10, 查看TPS和吞吐量信息

如果%util接近100%,表明I/O请求太多,I/O系统已经满负荷,磁盘可能存在瓶颈,一般%util大于70%,I/O压力就比较大,读取速度有较多的wait,然后再看其他的参数。


rrqm/s:每秒进行merge的读操作数目。即delta(rmerge)/s
wrqm/s:每秒进行merge的写操作数目。即delta(wmerge)/s
r/s:每秒完成的读I/O设备次数。即delta(rio)/s
w/s:每秒完成的写I/0设备次数。即delta(wio)/s
rsec/s:每秒读扇区数。即delta(rsect)/s
wsec/s:每秒写扇区数。即delta(wsect)/s
rKB/s:每秒读K字节数。是rsec/s的一半,因为每扇区大小为512字节

wKB/s:每秒写K字节数。是wsec/s的一半
avgrq-sz:平均每次设备I/O操作的数据大小(扇区)。即delta(rsect+wsect)/delta(rio+wio)
avgqu-sz:平均I/O队列长度。即delta(aveq)/s/1000(因为aveq的单位为毫秒)
await:平均每次设备I/O操作的等待时间(毫秒)。即delta(ruse+wuse)/delta(rio+wio)
svctm:平均每次设备I/O操作的服务时间(毫秒)。即delta(use)/delta(rio+wio)
%util:一秒中有百分之多少的时间用于I/O操作,或者说一秒中有多少时间I/O队列是非空的


iostat -c 1 2

查看cpu状态

间隔1秒显示一次,总共显示2次


3、找出使用io高的进程的工具 iotop

yum install iotop -y

直接执行 iotop 命令

4、lsof查看端口占用情况

需要安装 :yum -y install lsof

[root@www ~]# lsof -i:3306

COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME

mysqld 1183 mysql 33u IPv6 24958 0t0 TCP *:mysql (LISTEN)

mysqld 1183 mysql 36u IPv6 44440 0t0 TCP docker0:mysql->192.168.1.5:49900 (ESTABLISHED)

mysqld 1183 mysql 38u IPv6 11204 0t0 TCP docker0:mysql->192.168.1.5:54593 (ESTABLISHED)


lsof -i 列出占用端口情况

lsof -i:80


二: iostat命令简介

iostat命令主要用于输出磁盘IO和CPU的统计信息。iostat首次运行时显示自系统启动开始的各项统计信息,之后运行iostat将显示自上次运行该命令以后的统计信息。用户可以通过指定统计的次数和时间来获得所需的统计信息。iostat命令通过观察设备相对于其平均传输速率处于活动状态的时间来监控系统输入/输出设备负载。iostat命令生成可用于更改系统配置的报告,以更好地平衡物理磁盘之间的输入/输出负载。centos7默认未安装此命令,此命令包含在软件包sysstat中。

如果%iowait的值过高,表示硬盘存在I/O瓶颈,%idle值高,表示CPU较空闲,如果%idle值高但系统响应慢时,有可能是CPU等待分配内存,此时应加大内存容量。%idle值如果持续低于10,那么系统的CPU处理能力相对较低,表明系统中最需要解决的资源是CPU。

如果 %util 接近 100%,说明产生的I/O请求太多,I/O系统已经满负荷,该磁盘可能存在瓶颈。如果 svctm 比较接近 await,说明 I/O 几乎没有等待时间;如果 await 远大于 svctm,说明I/O 队列太长,io响应太慢,则需要进行必要优化。如果avgqu-sz比较大,也表示有当量io在等待。

2.1:获取命令帮助

[root@www ~]# man iostat

2.2: 查看命令版本

[root@www ~]# iostat -V

sysstat 版本 10.1.5

(C) Sebastien Godard (sysstat <at> orange.fr)

2.3:显示所有设备负载情况

[root@www ~]# iostat

Linux 3.10.0-1160.71.1.el7.x86_64 (www.yhchange.com) 2023年08月20日 x86_64 (8 CPU)

avg-cpu: %user %nice %system %iowait %steal %idle

0.05 0.00 1.49 0.57 0.00 97.90

Device: tps kB_read/s kB_wrtn/s kB_read kB_wrtn

sda 441.08 65.00 1394.64 884122 18971022

scd0 0.00 0.00 0.00 44 0



2.4:间隔2秒查看:5次

[root@www ~]# iostat 2 5


2.5:间隔3秒显示一次磁盘信息

[root@www ~]# iostat -d 3

2.6: 间隔5秒显示sda磁盘的详细信息

[root@www ~]# iostat -x -m sda 5

2.7:显示磁盘及其分区的状态信息

[root@www ~]# iostat -p

2.8: 报告每秒向终端读取和写入的字符数

[root@www ~]# iostat -t

2.9:间隔3秒显示2次CPU信息

[root@www ~]# iostat -c 3 2


三: 使用语法及参数说明

3.1: 使用语法

用法:iostat [ options ] [ <interval> [ <count> ] ]

3.2: 参数说明


3.3: 输出项说明

  • avg-cpu: 总体cpu使用情况统计信息,对于多核cpu,这里为所有cpu的平均值。重点关注iowait值,表示CPU用于等待io请求的完成时间。
  • Device: 各磁盘设备的IO统计信息。

3.4:CPU属性值列说明


3.5:磁盘属性值列说明














相关推荐
何陈陈2 分钟前
【Linux】线程池
linux·服务器·开发语言·c++
S hh4 分钟前
【Linux 】文件描述符fd、重定向、缓冲区(超详解)
linux·运维·服务器
DuoRuaiMiFa4 分钟前
Linux系统性能调优实战指南
linux
沉登c5 分钟前
Javascript客户端时间与服务器时间
服务器·javascript
憧憬一下6 分钟前
线程池的实现和讲解:解决多线程并发服务器创建销毁线程消耗过大的问题
linux·线程池·c/c++·嵌入式linux
碳治郎AI17 分钟前
Bolt.new:终极自动化编程工具
运维·自动化
朝九晚五ฺ1 小时前
【Linux探索学习】第三弹——Linux的基础指令(下)——开启新篇章的大门
linux·运维·学习
肥or胖1 小时前
【MySQL】索引
linux·数据库·mysql
原机小子2 小时前
Spring Boot框架下的新闻推荐技术
服务器·spring boot·php
卓琢2 小时前
(九)Shell 脚本(四):正则表达式、sed 和 awk 详解
linux·mysql·正则表达式