工具准备:
iotop: http://guichaz.free.fr/iotop/
pt-ioprofile: http://www.percona.com/downlo...
IO高分析方法:
1、查看磁盘使用率 df -lh
2、安装iostat 安装命令: yum install sysstat
3、iostat -d -k 2 查看IO情况:
哪个磁盘的IO负载较高,接下来我们就来定位具体的负载来源
文章图片
%util: 一秒中有百分之多少的时间用于 I/O 操作,或者说一秒中有多少时间 I/O 队列是非空的。即 delta(use)/s/1000 (因为use的单位为毫秒)
如果 %util 接近 100%,说明产生的I/O请求太多,I/O系统已经满负荷,该磁盘可能存在瓶颈。
文章图片
4、安装iotop 命令:
安装命令:yum install iotop iotop 查看哪个线程耗IO比较高、按 o 只显示有磁盘 IO 活动的进程。
文章图片
5、pt-ioprofile定位负载来源文件
pt-ioprofile --profile-pid=1236 --cell=sizes
pt-ioprofile的原理是对某个pid附加一个strace进程进行IO分析。
文章图片
6、对于定位问题更有用的是通过IO的吞吐量来进行定位。使用参数 --cell=sizes,该参数将结果已 B/s 的方式展示出来
pt-ioprofile --profile-pid=1236 --cell=sizes
从上图可以看出IO负载的主要来源是jetty。
并且压力主要集中在读取上。
【面试官(磁盘 IO 变高,你怎么分析())】来源 | https://urlify.cn/JNRVJb
推荐阅读
- Java|Java基础——数组
- 人工智能|干货!人体姿态估计与运动预测
- java简介|Java是什么(Java能用来干什么?)
- Java|规范的打印日志
- Linux|109 个实用 shell 脚本
- 程序员|【高级Java架构师系统学习】毕业一年萌新的Java大厂面经,最新整理
- Spring注解驱动第十讲--@Autowired使用
- SqlServer|sql server的UPDLOCK、HOLDLOCK试验
- jvm|【JVM】JVM08(java内存模型解析[JMM])
- 技术|为参加2021年蓝桥杯Java软件开发大学B组细心整理常见基础知识、搜索和常用算法解析例题(持续更新...)