磁盘读/写瓶颈如何使用iostat、iotop、和pidstat定位罪魁祸首

磁盘读写瓶颈如何使用iostat、iotop、和 pidstat定位罪魁祸首

  • 一、iostat工具
    • 1.1 iostat简介
    • 1.2 iostat命令使用
    • 1.3 案例介绍
  • 二、iotop工具
    • 2.1 iotop简介
    • 2.2 iotop命令使用
    • 2.3 案例介绍
  • 三、pidstat工具
    • 3.1 pidstat简介
    • 3.2 pidstat命令使用
    • 3.3 案例介绍
  • 总结

在现代计算机系统中,磁盘I/O瓶颈是影响系统性能的常见问题之一。本文将介绍如何使用iostatiotoppidstat这三个工具来定位磁盘读写瓶颈的罪魁祸首。我们将通过层层递进的排查方法,结合详细的案例介绍和命令使用参数解释,帮助你更好地理解和解决磁盘I/O瓶颈问题。

一、iostat工具

1.1 iostat简介

iostat是一个用于监控系统输入/输出设备负载的工具。它可以报告CPU使用情况和I/O设备的使用情况,帮助我们了解系统的I/O性能。

1.2 iostat命令使用

以下是一些常用的iostat命令及其参数解释:

# 显示所有设备的I/O统计信息
iostat
# 每隔2秒显示一次I/O统计信息,显示5次
iostat -d 2 5
# 显示设备的详细I/O统计信息
iostat -x

1.3 案例介绍

假设我们发现系统的磁盘I/O性能较差,可以使用以下命令来查看详细的I/O统计信息:

iostat -x 2 5

通过分析输出结果,我们可以确定哪些设备的I/O负载较高,从而进一步定位问题。

[root@Energetic ~]# iostat -x 2 5
Linux 3.10.0-1160.15.2.el7.x86_64 (Energetic ) 07/25/2024 _x86_64_(4 CPU)avg-cpu:  %user   %nice %system %iowait  %steal   %idle3.79    0.00    2.00    0.01    0.00   94.21Device:         rrqm/s   wrqm/s     r/s     w/s    rkB/s    wkB/s avgrq-sz avgqu-sz   await r_await w_await  svctm  %util
sdb               0.00     0.00    0.00    0.00     0.00     0.55 39225.78     0.00   16.22    0.26   20.70   0.49   0.00
sda               0.00     0.02    0.00    0.48     0.02     3.97    16.67     0.01   28.97   24.86   28.97  22.91   1.10
sdc               0.00     0.00    0.00    0.09     0.01    11.68   260.01     0.01   60.93   23.27   60.96  21.81   0.20
dm-0              0.00     0.00    0.00    0.09     0.01    11.68   253.42     0.01   60.12   23.28   60.15  20.96   0.19avg-cpu:  %user   %nice %system %iowait  %steal   %idle31.91    0.00    4.02    0.00    0.00   64.07Device:         rrqm/s   wrqm/s     r/s     w/s    rkB/s    wkB/s avgrq-sz avgqu-sz   await r_await w_await  svctm  %util
sdb               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
sda               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
sdc               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
dm-0              0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00avg-cpu:  %user   %nice %system %iowait  %steal   %idle42.06    0.00    3.04    0.00    0.00   54.89Device:         rrqm/s   wrqm/s     r/s     w/s    rkB/s    wkB/s avgrq-sz avgqu-sz   await r_await w_await  svctm  %util
sdb               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
sda               0.00     0.00    0.00    1.00     0.00     4.00     8.00     0.00    2.50    0.00    2.50   3.50   0.35
sdc               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
dm-0              0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00avg-cpu:  %user   %nice %system %iowait  %steal   %idle7.10    0.00    2.28    0.00    0.00   90.63Device:         rrqm/s   wrqm/s     r/s     w/s    rkB/s    wkB/s avgrq-sz avgqu-sz   await r_await w_await  svctm  %util
sdb               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
sda               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
sdc               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
dm-0              0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00avg-cpu:  %user   %nice %system %iowait  %steal   %idle6.19    0.00    2.37    0.00    0.00   91.44Device:         rrqm/s   wrqm/s     r/s     w/s    rkB/s    wkB/s avgrq-sz avgqu-sz   await r_await w_await  svctm  %util
sdb               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
sda               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
sdc               0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00
dm-0              0.00     0.00    0.00    0.00     0.00     0.00     0.00     0.00    0.00    0.00    0.00   0.00   0.00[root@Energetic  ~]# 

比如当前主机上的磁盘有sda、sdb、sdc、dm-0,我们首先使用iostat确定存储设备,可以根据数据存放推断具体是哪个服务进程在使用磁盘。

确定了磁盘之后我们可以使用iotop继续排查

二、iotop工具

2.1 iotop简介

iotop是一个类似于top的工具,但它专门用于显示各个进程的I/O使用情况。通过iotop,我们可以实时监控各个进程的I/O活动,找出I/O瓶颈的具体进程。

2.2 iotop命令使用

以下是一些常用的iotop命令及其参数解释:

# 以交互模式显示I/O使用情况
sudo iotop# 显示所有进程的I/O使用情况,包括后台进程
sudo iotop -a# 仅显示实际发生I/O操作的进程
sudo iotop -o

2.3 案例介绍

假设我们怀疑某个进程导致了磁盘I/O瓶颈,可以使用以下命令来查看各个进程的I/O使用情况:

sudo iotop -o

通过观察输出结果,我们可以找出I/O使用较高的进程,从而进一步分析和解决问题,以下是一个参考。

Total DISK READ :0.00 B/s | Total DISK WRITE :7.80 K/s
Actual DISK READ:0.00 B/s | Actual DISK WRITE:7.80 K/sTID  PRIO  USER     DISK READ  DISK WRITE  SWAPIN     IO>    COMMAND                                                                                                                        
20912 be/4 root0.00 B/s    3.90 K/s  0.00 %  0.00 % SmartAgent1754 be/4 root0.00 B/s    3.90 K/s  0.00 %  0.00 % python -u bin/WALinuxAgent-2.7.0.6-py2.7.egg -run-exthandlers

详细了解各个进程的性能表现可以继续使用pidstat

三、pidstat工具

3.1 pidstat简介

pidstat是一个用于监控各个进程性能的工具。它可以报告CPU、内存、I/O等资源的使用情况,帮助我们详细了解各个进程的性能表现。

3.2 pidstat命令使用

以下是一些常用的pidstat命令及其参数解释:

# 显示所有进程的I/O统计信息
pidstat -d# 每隔2秒显示一次所有进程的I/O统计信息,显示5次
pidstat -d 2 5# 显示指定进程的I/O统计信息
pidstat -d -p <pid>

3.3 案例介绍

假设我们需要详细分析某个进程的I/O使用情况,可以使用以下命令来查看该进程的I/O统计信息:

pidstat -d -p <pid>

通过分析输出结果,我们可以了解该进程的I/O使用情况,从而进一步定位和解决问题。

总结

通过本文介绍的iostatiotoppidstat这三个工具,我们可以有效地定位磁盘读写瓶颈的罪魁祸首。希望这些工具和方法能帮助你更好地解决磁盘I/O性能问题,提高系统的整体性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/50210.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Pytorch使用教学5-视图view与reshape的区别

有同学后台留言问为什么view有时可对张量进行形变操作&#xff0c;有时就会报错&#xff1f;另外它和reshape功能好像一致&#xff0c;有什么区别呢&#xff1f;本文就带你了解PyTorch中视图的概念。 在PyTorch中对张量进行形变操作时&#xff0c;很多同学也会使用view方法&am…

监测Nginx访问日志状态码,并做相应动作

文章目录 引言I 监测 Nginx 访问日志情况,并做相应动作1.1 前提准备1.2 访问日志 502 情况,重启 bttomcat9服务1.3 其他案例:访问日志 502 情况,重启 php-fpm 服务II 将Shell 脚本check499.sh包装成systemd服务2.1 创建systemd服务2.2 配置service2.3 开机启动2.4 其他常用…

jetbrains InterlliJ IDEA 2024.1 版本最新特性一览: Java 相关内容

简简单单 Online zuozuo:欢迎商业合作 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo :本心、输入输出、结果 简简单单 Online zuozuo :联系我们:VX :tja6288 / EMAIL: 347969164@qq.com 文章目录 jetbrains InterlliJ …

华为ICT大赛之ensp软件BGP原理与配置

BGP基础 1.用于不同自治系统AS(autonomous system)之间动态交换路由信息&#xff1b; BGP取代EGP(exterior gateway protocol)外部网关协议&#xff0c;BGP在其发布路由信息基础上可以进行路由优选&#xff0c;高效处理路由信息&#xff1b; AS:同一组织管理下&#xff0c;使…

一线工作中常用 Shell 脚本: Jar包部署为linux系统服务; 恶意访问,安全防范; SSH 免交互执行命令;

文章目录 引言进程相关Jar包部署为linux系统服务杀死进程脚本恶意访问,安全防范屏蔽每分钟访问超过200的IP屏蔽每分钟SSH尝试登录超过10次的IP检测网卡流量,并按规定格式记录在日志中SSH相关ssh远程执行命令SSH 免交互执行命令批量修改服务器用户密码文件相关常用命令从 FTP …

tmux相关命令

tmux相关命令 1、tmux介绍2、会话&#xff08;session&#xff09;、窗口&#xff08;windows&#xff09;、窗格&#xff08;pane&#xff09;3、会话相关命令4、窗口相关命令5、窗格相关命令6、内容查看7、tmux配置文件 1、tmux介绍 略 2、会话&#xff08;session&#xf…

Failed to start mysql.service: Unit not found

遇到 "Failed to start mysql.service: Unit not found" 的错误通常意味着 mysql.service 这个服务单元文件在你的系统中不存在。这可能是因为你安装的是 MariaDB 而不是 MySQL&#xff0c;或者 MySQL 服务单元文件丢失或未正确安装。 下面是解决这个问题的一些步骤&…

在中标麒麟系统V4.0 (Linux 3.10.0内核, 3A4000处理器) 上专业安装英伟达或AMD显卡驱动的详细指南

在中标麒麟系统V4.0&#xff0c;基于Linux 3.10.0内核&#xff0c;3A4000处理器上安装英伟达或AMD显卡驱动是一个复杂且涉及深度定制和兼容性的任务。以下是详细步骤和技术要点&#xff1a; 1. 前期准备 确认系统环境 操作系统&#xff1a;中标麒麟系统V4.0内核版本&#xf…

RK3568平台(显示篇)显示系统基本概念

一.显示系统概述 linux内核中包含两类图形显示设备驱动框架&#xff1a; FB设备&#xff1a;Framebuffer图形显示框架;DRM&#xff1a;直接渲染管理器&#xff08;Direct Rendering Manager&#xff09;&#xff0c;是linux目前主流的图形显示框架&#xff1b; 在实际场景中…

打通“链上数据脉络” 欧科云链数字生态建设成果凸显

7月25日&#xff0c;据Coindesk报道&#xff0c;全球领先的区块链技术和服务提供商欧科云链宣布旗下OKLink浏览器与Polygon Labs正式达成合作&#xff0c;成为AggLayer首个区块链搜索引擎及Web3数据分析平台&#xff0c;将为开发者提供精简易用的链上数据访问和开发工具&#x…

MATLAB学习教程(一)

目录 1.常见函数基本运算 2.二维绘制: plot(​..) 3.三维绘制: plot3(​..) / mesh(​..) 4.绘图美化 标题及标签 绘图命令&#xff1a;color 绘图命令&#xff1a;Line 5.代码 1.常见函数基本运算 方根函数sqrt() 自然指数函数exp() 以10为底的对数函…

巴斯勒相机(Basler) ACE2 dart 系列说明和软件

巴斯勒相机(Basler) ACE2 dart 系列说明和软件

计算机网络中的加密技术与公钥基础设施(PKI)

在现代计算机网络中&#xff0c;加密技术和公钥基础设施&#xff08;PKI&#xff09;是保护数据安全和隐私的核心要素。随着网络攻击和数据泄露事件的增加&#xff0c;加密技术和 PKI 在保障网络通信安全、身份认证和数据完整性方面发挥了至关重要的作用。本文将深入探讨加密技…

了解高防 IP

一、高防 IP 的基本概念 高防 IP 是指拥有强大防御能力的 IP 地址。它主要通过将攻击流量引流到高防机房进行清洗和过滤&#xff0c;再将正常的流量回注到源站&#xff0c;从而保障源站服务器的稳定运行。 二、高防 IP 的工作原理 当用户的服务器遭受 DDoS 攻击时&#xff0…

前端获取blob文件格式的两种格式

第一种,后台传递给前台是base64格式的JSON数据 这时候前台拿到base64格式的数据可以通过内置的atob解码方法结合new Uint8Array和new Blob方法转换成blob类型的数据格式,然后可以使用blob数据格式进行操作,虽然base64转换成blob要经过很多步骤,但幸运的是这些步骤都是固定的,因…

Ubuntu22.04手动安装fabric release-2.5版本

这个过程稍微有点复杂&#xff0c;但完整操作完成以后会对Fabric网络有更加深入的理解&#xff0c;方便后续自己手动搭建Fabric网络。这个过程需要手动逐个下载Fabric源代码、使用命令下载Fabric镜像和用Git下载例子程序。 Fabric源代码主要用途是用来编译cryptogen、configtx…

科普文:Linux系统安全加固指南

本指南仅关注安全性和隐私性&#xff0c;而不关注性能&#xff0c;可用性或其他内容。 列出的所有命令都将需要root特权。以“$”符号开头的单词表示一个变量&#xff0c;不同终端之间可能会有所不同。 选择正确的Linux发行版 选择一个好的Linux发行版有很多因素。 避免分发…

redis的使用场景

目录 1. 热点数据缓存 1.1 什么是缓存&#xff1f; 1.2 缓存的原理 1.3 什么样的数据适合放入缓存中 1.4 哪个组件可以作为缓存 1.5 java使用redis如何实现缓存功能 1.5.1 需要的依赖 1.5.2 配置文件 1.5.3 代码 1.5.4 发现 1.6 使用缓存注解完成缓存功能 2. 分布式锁…

【Python Web】Flask扩展开发指南

Flask是一个轻量级的Python Web框架&#xff0c;它提供了丰富的扩展库和工具&#xff0c;可以帮助开发者快速构建Web应用。本篇博客将介绍如何进行Flask扩展开发&#xff0c;包括扩展的创建、配置、使用等方面的内容。 目录 Flask扩展开发指南 一、Flask扩展简介 二、创建Fl…

【算法】字典序最小的 01 字符串

字典序最小的 01 字符串 题目描述 小红有一个 01 字符串&#xff0c;她可以进行最多 k 次提作&#xff0c;每次操作可以交换相邻的两个字符&#xff0c;问可以得到的字典序最小的字符串是什么。 输入描述 第一行包含两个整数&#xff0c;n&#xff08;1 < n < 10^5&a…