遇到liunx服务器IO负载,读IO流量峰值347MB/s,排查并解决。

前言:

根据监控报警看到IO读的速度为347MB/s。

统计时间区段 统计时长 IOPS IO流量 状态

1 工作日上班时间段:08:00-18:00 1小时平均值 >2000 >200 MB/s 异常

4小时平均值 >1500 >150 MB/s 异常

8小时平均值 >1000 >100 MB/s 异常

持续7天 >500 >50 MB/s 异常

2 工作日非上班时段:18:00-08:00 1小时平均值 >4000 >300 MB/s 异常

4小时平均值 >3000 >200 MB/s 异常

12小时平均值 >2000 >100 MB/s 异常

持续7天 >1000 >80 MB/s 异常

通过iostat、iotop、top、vmstat 、pidstat命令排查

查看磁盘 I/O 整体情况

bash 复制代码
iostat -x 1 10
参数解释:-x 表示显示详细信息;1 表示每隔 1 秒输出一次数据;10 表示总共输出 10 次。
关键指标分析:关注 %util(设备利用率)、r/s(每秒读取次数)、w/s(每秒写入次数)、r_await(读请求平均等待时间)、w_await(写请求平均等待时间)等指标。若 %util 接近或达到 100%,说明磁盘设备繁忙;r_await 和 w_await 数值高则表示 I/O 请求等待时间长。

可报告虚拟内存统计信息,也能显示磁盘 I/O 情况。

bash 复制代码
vmstat
参数解释:每隔 1 秒输出一次数据。

定位高 I/O 进程

bash 复制代码
iotop
使用方法:直接运行该命令后,会按 I/O 使用率降序显示进程信息。可以看到每个进程的读写速率、累计读写数据量等信息,从而快速定位产生大量 I/O 的进程。

用于监控指定进程或所有进程的 I/O 统计信息。

bash 复制代码
pidstat -d 1
参数解释:-d 表示显示 I/O 统计信息;1 表示每隔 1 秒输出一次数据。

1、通过iotop命令看出mysql查看进程占用cpu和free使用率高;

2、使用iostat命令查看出mysql这个进程占用io比较高;

3、然后登陆mysql 执行这条sql语句查看是否有锁表的show full processlist;(查看有两个查询语句卡死在那了,直接使用kill 杀掉,但是过一会儿还是没有正常。)

4、通过SHOW OPEN TABLES WHERE In_use > 0; 这条sql语句进行查询返回1的表名说明正在锁表不能对这张表进行操作,查看出一张表正在锁表,然后查看这是一张日志表数据比较大,没有用的垃圾数据进行清理掉了。

5、清理完日志表进行查看是否还有锁表的,发现没有锁表的了。于是加了一个定时任务,每天清理这张日志表的垃圾数据。

6、此服务器只部署了mysql,所以第一时间就定位到了mysql。

相关推荐
王二端茶倒水11 小时前
智慧小区宽带无线运营:从网络交付到认证、计费与运维闭环
运维·物联网·架构
旅僧11 小时前
远程终端工具安装
运维
OpsEye11 小时前
日志、指标、链路追踪,谁更适合定位故障?
运维·监控·日志分析
麦麦麦当劳大王11 小时前
Linux SSH服务端配置指南
linux·运维·服务器·ssh
xiami_world12 小时前
私有化部署协同白板选型指南:从Docker容器化到信创全栈适配的架构实践
运维·人工智能·docker·ai·持续部署
weixin_3077791312 小时前
从脚本执行到智能体协作:AI辅助测试能力的范式重构
运维·开发语言·人工智能·算法·测试用例
Yiyaoshujuku12 小时前
化学谱图数据API接口,数据字段一览!
linux·服务器·前端
阿坤带你走近大数据12 小时前
Linux中管道符的作用
java·linux·服务器
Fcy64812 小时前
Linux下 进程信号初识和信号的产生
linux·运维·信号的产生
爱装代码的小瓶子12 小时前
安工大Linux考点分类真题解析(含知识点是试卷原题了)
linux·服务器·网络·c