性能分析排查思路之机器(2)

前言

本文是性能问题分析排查思路的展开内容之一,第2篇,主要分为日志1期,机器4期、环境2期共7篇系列文章,本期是第二篇,讲机器(硬件)的存储方面的分析方法和经验、最佳实践。

机器上主要有磁盘(存储)、网络、内存和CPU四大硬件模块。其中磁盘方面是故障率、瓶颈率最高的一个部件。

对于Linux环境性能问题的排查,我们首先需要看的就是磁盘的情况。

了解构成

  • 分为RAID和非RAID的情况。RAID之后的磁盘阵列情况如果不清楚,可以使用MegaCli这个神器进行查询。 查询截图:

RAID级别对应关系:

  • Primary-1, Secondary-0, RAID Level Qualifier-0 RAID 1

  • Primary-0, Secondary-0, RAID Level Qualifier-0 RAID 0

  • Primary-5, Secondary-0, RAID Level Qualifier-3 RAID 5

  • Primary-1, Secondary-3, RAID Level Qualifier-0 RAID 10

  • 没有做RAID的磁盘,可以直接使用smartctl了解磁盘的属性。 执行命令:smartctl -i /dev/sdb的主要结果:

结果关注:厂家、产品型号、容量、转速7200,SAS传输协议等。

  • 可以使用lsblk命令查看磁盘的挂载情况,以及文件系统类型。

结果可以看到多数是xfs文件系统,且能查到UUID等信息。

  • 此外,可以使用lshw查看磁盘信息。

lshw -class disk命令的输出与smart信息类似,也可以看型号、序列号和转速信息,此外可以看到逻辑设备名称。

确认空间

  • df -h 主要看下是否存在磁盘空间使用耗尽的情况!生产上许多奇怪的问题可能是磁盘写满导致的!

查看速率

  • 使用sar -dp 3 5这个命令查看实时速率。

主要关注最列一列的使用率,达到100%说明读写请求过多,具体什么负载高可以看前面几列的数据。

  • 一般磁盘使用率存在问题的话,通过实时查看读写请求情况可以了解。

检测坏盘

  • smartctl -a查看Health字段
  • badblocks 命令,不能检测太大的盘
  • 一般磁盘故障的话机器的磁盘会有具体的告警,或者日志有I/O Error。

结语

本文探讨了与磁盘和文件系统相关的各种命令及其在性能分析中的应用。这些命令不仅可以帮助我们诊断和解决磁盘与文件系统的常见问题,还能提供宝贵的性能数据,从而优化系统的整体表现。

最后,我们要强调的是,磁盘和文件系统的性能对于整个系统的运行至关重要。因此,我们应该时刻关注其健康状况,并采取必要的措施来预防潜在的问题。

相关推荐
Yupureki4 小时前
《实战项目-个人在线OJ平台》1.项目简介和演示
c语言·数据结构·c++·sql·算法·性能优化·html5
小羊子说6 小时前
关于车机中的升级流程小结(SOC、MCU、4G升级流程)
android·adb·性能优化·车载系统
IDC02_FEIYA7 小时前
SQL Server 2016及SQL Server Management Studio下载,SQL Server 2016数据库安装教程图解
服务器·数据库·性能优化
小羊子说7 小时前
Android 车机开发中常用的adb 脚本(更新中)
android·linux·adb·性能优化·车载系统
莫爷8 小时前
JSON 进阶技巧:Schema 验证、JSONPath 查询、性能优化
性能优化·json
Gauss松鼠会1 天前
【GaussDB】GaussDB 重要内存参数设置
数据库·oracle·性能优化·database·gaussdb
被考核重击1 天前
虚拟列表(动态高度,性能优化,骨架屏)
javascript·vue.js·性能优化·虚拟列表
桌面运维家1 天前
Windows Hyper-V:VHD/VHDX磁盘性能优化指南
windows·性能优化
weixin_307779131 天前
2025年中国研究生数学建模竞赛A题:通用神经网络处理器下的核内调度问题——解决方案与实现
开发语言·人工智能·python·数学建模·性能优化
小陈工1 天前
2026年3月23日技术资讯洞察:AI Agent失控,Claude Code引领AI编程新趋势
开发语言·数据库·人工智能·后端·python·性能优化·ai编程