Linux 查看磁盘 查看磁盘IO并找出占用 并找出占用IO读写很高的进程

zz/2024/7/13 12:36:34

前言

  • 系统:Centos
  • 环境:测试环境
  • 服务器类型:联想(ThinkServer)塔式服务器 TS250
  • 测试童鞋反馈系统很卡,保存数据非常非常慢,第一反应是重启应用及数据库,不一会说还是非常慢,还是使用了重启大法,直接把服务器重启了,最后发现还是没解决问题。
  • 然后定位到是mysql写入数据很慢问题,又倒腾了大半天,主从同步,binlog日志清理等等,最终还是没解决问题,偶然发现服务器编辑保存文件都很慢,恍然大悟可能是服务器磁盘IO占比比较高,需要找出占比比较高的那个PID。
  • 执行命令:iotop -oP
  • 在这里插入图片描述

插个题外话,最终这个问题似乎也没解决

先说说用到哪些命令

  • 如果没有 iostat 命令,那么使用 yum install sysstat 进行安装
  • iostat -x 1 10
    在这里插入图片描述

字段说明

  • Device:设备名称
  • tps:每秒的IO读、写请求数量,多个逻辑请求可以组合成对设备的单个I/O请求。
  • Blk_read/s (kB_read/s, MB_read/s):从设备读取的数据量,以每秒若干块(千字节、兆字节)表示。块相当于扇区,因此块大小为512字节。
  • Blk_wrtn/s (kB_wrtn/s, MB_wrtn/s):写入设备的数据量,以每秒若干块(千字节、兆字节)表示。块相当于扇区,因此块大小为512字节。
  • Blk_read (kB_read, MB_read):读取块的总数(千字节、兆字节)。
  • Blk_wrtn (kB_wrtn, MB_wrtn):写入块的总数(千字节,兆字节)。
  • rrqm/s:每秒合并到设备的读请求数。即delta(rmerge)/s
  • wrqm/s:每秒合并到设备的写入请求数。即delta(wmerge)/s
  • r/s:每秒完成的读I/O设备次数。即delta(rio)/s
  • w/s:每秒完成的写I/0设备次数。即delta(wio)/s
  • rsec/s (rkB/s, rMB/s):每秒读取设备的扇区数(千字节、兆字节)。每扇区大小为512字节
  • wsec/s (wkB/s, wMB/s):每秒写入设备的扇区数(千字节、兆字节)。每扇区大小为512字节
  • avgrq-sz:平均每次设备I/O操作的数据量(扇区为单位)。即delta(rsec+wsec)/delta(rio+wio)
  • avgqu-sz:平均每次发送给设备的I/O队列长度。
  • await:平均每次IO请求等待时间。(包括等待队列时间和处理时间,毫秒为单位)
  • r_await:平均每次IO读请求等待时间。(包括等待队列时间和处理时间,毫秒为单位) w_await:平均每次IO写请求等待时间。(包括等待队列时间和处理时间,毫秒为单位)
  • svctm:平均每次设备I/O操作的处理时间(毫秒)。警告!不要再相信这个字段值,这个字段将在将来的sysstat版本中删除。
  • %util:一秒中有百分之多少的时间用于I/O操作,或者说一秒中有多少时间I/O队列是非空的。当该值接近100%时,设备饱和发生。

找到IO占用高的进程

  • 通过 iotop 命令
  • 如果没有该命令,请通过yum install iotop进行安装。
  • iotop -oP
  • 在这里插入图片描述

接到上面说的我的问题并没有解决

  • 发现我这个IO占用比较高是 md126_raid1 这根本不是我运行的应用呀。
  • 又倒腾半天,查阅各种资料(百度都快搜烂啦) ,这是我的各种搜索历史
    在这里插入图片描述
  • 最终确定为是不是前两天突然断电造成服务器磁盘损坏问题。
  • 此时联系到了联想的售后工程师,又是一顿沟通,最终确定磁盘是好的。
  • 然后IO占用100%也没最终的答案,就说可能是断电导致的问题,
  • 建议备份数据重装系统(说了等于白说)。。。。

最终也没解决,难道只有重装系统吗???

  • 有木有大佬帮帮小弟的。

参考文献

https://blog.csdn.net/sumengnan/article/details/109462795
https://blog.csdn.net/weixin_39945915/article/details/116777802
https://blog.csdn.net/chinalinuxzend/article/details/1856287

https://blog.csdn.net/iteye_2140/article/details/82103507
https://blog.csdn.net/hixiaoxiaoniao/article/details/86580128


http://www.ngui.cc/zz/2748852.html

相关文章

【面试大全-Spring】Spring Bean是如何创建的

在Spring中,万物都是bean对象,每一个对象都可以封装成BeanDefinition,然后去生成bean对象。 所以首先第一步,spring要找到哪些bean需要实例化,第一种是xml的方式,如果需要实例化bean就在xml中配置bean标签&…

【面试大全-Java】必备基础

Java语言有哪些特点 简单易学、提供丰富的类库面向对象、高内聚低耦合与平台无关、JVM跨平台可靠安全、支持多线程面向对象和面向过程的区别 面向过程:是分析解决问题的步骤,然后用函数把这些步骤一步步实现,然后在使用的时候一起调用即可,性能较高,所以单片机嵌入式开发都…

【元宇宙】当前元宇宙运行规则问题与展望

一、背景:愈演愈烈的“元宇宙热” 当赛博朋克科幻小说《雪崩》(Snow Crash)在1992年发表之时,作者尼尔斯蒂芬森(Neal Stephenson)绝不会想到自己提出的“元宇宙”(Metaverse)概念竟然会在十九年后的资本市场…

6月26日网络编程

网络编程 1、软件之间通信条件: a.找到对方IP b.数据要发送到对方指定的应用程序上,为了表示这些程序,所以给这些网络应用程序都用数字进行标示。 为了方便称呼这个数字,叫做端口,逻辑端口。 c.定义通信规则。既成…

7月02日SQL server条件以及高级查询

SQL server条件以及高级查询 --条件 --where 请问if() --select,update,delete需要加条件 --true flase --关系运算符&#xff1a; && || ! --> < > < ! and or not select *from student select *from student where saddress陕西 sel…

Android监听HOME键的另外一种方法

众所周知&#xff0c;我们监听返回键事件&#xff0c;无法是下面两个方法&#xff1a; Overridepublic void onBackPressed() {//do something//super.onBackPressed();}Overridepublic boolean onKeyDown(int keyCode, KeyEvent event) {if(keyCode KeyEvent.KEYCODE_BACK){/…

2014,写给25岁的自己

2014&#xff0c;写给25岁的自己 2012年6月&#xff0c;在我们以青春的名义&#xff0c;为逝去的大学生活而最后举杯之后&#xff0c;我毕业了。 2012年7月&#xff0c;拖着沉重的行李箱&#xff0c;我来到了这座熟悉又陌生的城市&#xff0c;开始了自己的第一份工作。 2012年…

Android Studio 中Gradle配置debug使用release的签名

当我们在做微信微博sdk分享的时候调试非常麻烦&#xff0c;因为要使用对应的签名版本才能调用sdk成功。 当我们使用AndroidStudio的Gradle之后会很简单的解决这个问题。 1.我们把签名文件放到工程根目录下&#xff08;这样做是为了保持路径的统一&#xff09; 2.在Gradle中引…

Java多线程之并发安全经典案例-卖票

转载请注明出处&#xff1a;http://blog.csdn.net/linglongxin24/article/details/52807454【DylanAndroid的csdn博客】 线程相关知识 1.创建线程的两种方式 继承Thread类。实现Runnable接口。&#xff08;这种方式较为常用&#xff09; 2.实现Runnable接口的好处 将线程的…

Java泛型应用之打造Android中ListView和GridView万能适配器【CommonAdapter】--超简洁写法

转载请注明出处&#xff1a;http://blog.csdn.net/linglongxin24/article/details/52813227 【DylanAndroid的csdn博客】 在android中使用最多的就是ListView&#xff0c;GridView&#xff0c;用到这两个控件那么肯定要用到适配器&#xff0c;那就是定义一个类继承BaseAdapter&…