linux小白如何衡量云硬盘的性能 根据性能选择硬盘

提供的块存储设备根据类型的不同拥有不同的性能和价格,详细信息请参见 云硬盘类型。由于不同应用程序的工作负载不同,若未提供足够的 I/O 请求来充分利用云硬盘时,可能无法达到云硬盘的最大性能。 一般使用以下指标衡量云硬盘的性能:

IOPS:每秒读/写次数,单位为次(计数)。存储设备的底层驱动类型决定了不同的 IOPS。

吞吐量:每秒的读写数据量,单位为MB/s。

时延:I/O 操作的发送时间到接收确认所经过的时间,单位为微秒

linux小白如何衡量云硬盘的性能 根据性能选择硬盘

操作前须知(重要)

警告

本文使用 FIO 作为测试工具,请不要在系统盘上进行 FIO 测试,避免损坏系统重要文件

为避免底层文件系统元数据损坏导致数据损坏,请不要在业务数据盘上进行测试。请使用测试机器未存放业务数据的云硬盘进行压测,并提前 创建快照 保障您的数据安全。

请确保/etc/fstab文件配置项中没有被测硬盘的挂载配置,否则将导致云服务器启动失败

测试工具

FIO 是测试磁盘性能的工具,用来对硬件进行压力测试和验证,本文以 FIO 为例。 使用 FIO 时,建议配合使用 libaio 的 I/O 引擎进行测试。请参见 工具安装 完成 FIO 和 libaio 的安装。

测试对象建议

建议在空闲的、未保存重要数据的硬盘上进行 FIO 测试,并在测试完后重新制作被测硬盘的文件系统。

测试硬盘性能时,建议直接测试裸数据盘(如 /dev/vdb)。

测试文件系统性能时,推荐指定具体文件测试(如 /data/file)。

工具安装

参见 使用标准登录方式登录 Linux 实例(推荐) 登录云服务器,本文以 CentOS 7.6 操作系统的云服务器为例。

执行以下命令,查看云硬盘是否4KiB对齐。

fdisk -lu

如下图所示,若返回结果中的 Start 值能被8整除即是4KiB对齐。否则请完成4KiB对齐后再进行测试。

linux小白如何衡量云硬盘的性能 根据性能选择硬盘

依次执行以下命令,安装测试工具 FIO 和 libaio。

yum install libaio -y
yum install libaio-devel -y
yum install fio -y

安装完成后,请参见测试示例开始进行云硬盘性能测试。

常见用例如下:

bs = 4k iodepth = 1:随机读/写测试,能反映硬盘的时延性能

执行以下命令,测试硬盘的随机写时延(/dev/target_device 替换成需要压测的设备名,压测前按注意事项做好快照备份

fio -bs=4k -ioengine=libaio -iodepth=1 -numjobs=1 -direct=1 -rw=randwrite -time_based -runtime=600 -refill_buffers -norandommap -randrepeat=0 -group_reporting -name=fio-randwrite-lat -size=10G -filename=/dev/target_device

执行以下命令,测试硬盘的随机读时延(/dev/target_device 替换成需要压测的设备名,压测前按注意事项做好快照备份)。

fio -bs=4k -ioengine=libaio -iodepth=1 -numjobs=1 -direct=1 -rw=randread -time_based -runtime=600 -refill_buffers -norandommap -randrepeat=0 -group_reporting -name=fio-randread-lat -size=10G -filename=/dev/target_device

执行以下命令,测试硬盘的随机混合读写时延(/dev/target_device 替换成需要压测的设备名,压测前按注意事项做好快照备份)。

fio -bs=4k -ioengine=libaio -iodepth=1 -numjobs=1 -direct=1 -rw=randrw -time_based -runtime=600 -refill_buffers -norandommap -randrepeat=0 -group_reporting -name=fio-randread-lat -size=10G -filename=/dev/target_device

示例:

登录云服务器后,执行以下命令,测试设备名为 /dev/vdc 的 SSD 云硬盘的随机混合读写时延性能

fio -bs=4k -ioengine=libaio -iodepth=1 -numjobs=1 -direct=1 -rw=randrw -time_based -runtime=100 -refill_buffers -norandommap -randrepeat=0 -group_reporting -name=fio-randrw-lat -size=1G -filename=/dev/vdc

测试结果如下图所示:

linux小白如何衡量云硬盘的性能 根据性能选择硬盘

bs = 4k iodepth = 32:随机读/写测试,能反映硬盘的 IOPS 性能

执行以下命令,测试硬盘的随机读 IOPS(/dev/target_device 替换成需要压测的设备名, 压测前按注意事项做好快照备份)。

fio -bs=4k -ioengine=libaio -iodepth=32 -numjobs=4 -direct=1 -rw=randread -time_based -runtime=600 -refill_buffers -norandommap -randrepeat=0 -group_reporting -name=fio-randread-iops -size=10G -filename=/dev/target_device

执行以下命令,测试硬盘的随机写 IOPS(/dev/target_device 替换成需要压测的设备名, 压测前按注意事项做好快照备份

fio -bs=4k -ioengine=libaio -iodepth=32 -numjobs=4 -direct=1 -rw=randwrite -time_based -runtime=600 -refill_buffers -norandommap -randrepeat=0 -group_reporting -name=fio-randwrite-iops -size=10G -filename=/dev/target_device

执行以下命令,测试硬盘的随机混合读写 IOPS(/dev/target_device 替换成需要压测的设备名, 压测前按注意事项做好快照备份

fio -bs=4k -ioengine=libaio -iodepth=32 -numjobs=4 -direct=1 -rw=randrw -time_based -runtime=600 -refill_buffers -norandommap -randrepeat=0 -group_reporting -name=fio-randrw-iops -size=10G -filename=/dev/target_device

示例:

登录云服务器后,执行以下命令,测试设备名为 /dev/vdc 的 SSD 云硬盘的随机读 IOPS 性能。

fio -bs=4k -ioengine=libaio -iodepth=32 -numjobs=4 -direct=1 -rw=randread -time_based -runtime=600 -refill_buffers -norandommap -randrepeat=0 -group_reporting -name=fio-randread-iops -size=10G -filename=/dev/vdc
linux小白如何衡量云硬盘的性能 根据性能选择硬盘

测试示例

不同场景的测试公式基本一致,只有 rw、iodepth 和 bs(block size)三个参数的区别。例如,每个工作负载适合的最佳 iodepth 不同,取决于您的特定应用程序对于 IOPS 和延迟的敏感程度。

参数说明:

参数名说明取值样例
bs每次请求的块大小。取值包括4k、8k及16k等。4k
ioengineI/O 引擎。推荐使用 Linux 的异步 I/O 引擎。libaio
iodepth请求的 I/O 队列深度。1
direct指定 direct 模式。True(1)表示指定 O_DIRECT 标识符,忽略 I/O 缓存,数据直写。False(0)表示不指定 O_DIRECT 标识符。默认为 True(1)。1
rw读写模式。取值包括顺序读(read)、顺序写(write)、随机读(randread)、随机写(randwrite)、混合随机读写(randrw)和混合顺序读写(rw,readwrite)。read
time_based指定采用时间模式。无需设置该参数值,只要 FIO 基于时间来运行。N/A
runtime指定测试时长,即 FIO 运行时长。100s
refill_buffersFIO 将在每次提交时重新填充 I/O 缓冲区。默认设置是仅在初始时填充并重用该数据。N/A
norandommap在进行随机 I/O 时,FIO 将覆盖文件的每个块。若给出此参数,则将选择新的偏移量而不查看 I/O 历史记录。N/A
randrepeat随机序列是否可重复,True(1)表示随机序列可重复,False(0)表示随机序列不可重复。默认为 True(1)。0
group_reporting多个 job 并发时,打印整个 group 的统计值。N/A
namejob 的名称。fio-read
sizeI/O 测试的寻址空间。1G
filename测试对象,即待测试的磁盘设备名称。/dev/sdb
numjobs并发线程数,默认为1。当被测试硬盘性能较高时推荐加大numjobs数(如2或4等)以增加压力。1

常见用例如下:

主题测试文章,只做测试使用。发布者:云大使,转转请注明出处:https://www.xp8.net/server/5585.html

(0)
打赏 微信扫一扫 微信扫一扫
云大使的头像云大使
上一篇 2026年1月13日 下午3:27
下一篇 2026年1月13日 下午3:56

相关推荐

  • centos下 du命令的使用方法分享(查看目录下的文件大小)

    du的用法 du命令用来查看目录或文件所占用磁盘空间的大小。常用选项组合为:du -sh du常用的选项:   -h:以人类可读的方式显示   -a:显示目录占用的磁盘空间大小,还要显示其下目录和文件占用磁盘空间的大小   -s:显示目录占用的磁盘空间大小,不要显示其下子目录和文件占用的磁盘空间大小   -c:显示几个目录或文件占用的磁盘空间大小,还要统计它…

    服务器运维 2019年11月10日
    4.1K00
  • 幻兽帕鲁windows腾讯云服务器快捷部署教程

    想要部署属于自己的幻兽帕鲁服务器(Dedicated Server),您首先需要拥有一台服务器,服务器是幻兽帕鲁运行的基础。部署完成后,您和您的朋友便可以登入专属的游戏服进行体验。使用云服务器搭建幻兽帕鲁服务器,便可以让您与您的朋友在一个相对独立且私密的空间中进行游戏,确保获得更加畅快的游戏体验。 您可以选择腾讯云轻量应用服务器作为游戏服务器,并按照下面教程…

    2024年1月24日
    3.6K10
  • Linux+Nginx下SSL证书安装

    [v_blue]一.Nginx安装SSL证书需要两个配置文件[/v_blue] 温馨提示:安装证书前请先备份您需要修改的服务器配置文件 1_root_bundle.crt、 2_domainname.com.key。注:这三个证书文件都在文件夹for Nginx.zip中,例:1_root_bundle.crt是根证书链(公钥),2_ domainname.…

    2018年4月2日
    3.9K00
  • 如何在Linux(centos)中用命令删除文件教程

    在Linux中可以使用多种方法来删除文件,下面本篇文章给大家介绍两种删除文件的方法:rm命令和trash-cli工具,希望对大家有所帮助。 rm命令 rm命令是大多数人在删除文件时经常使用的命令,它用于删除一个文件或者目录。 rm命令的语法如下: rm /path/to/file 还可以删除文件夹和子文件夹中的所有文件,如下所示: rm -R /path/t…

    2019年3月13日
    4.1K00
  • linux下中文乱码问题解决方案教程-学派吧

    如果您有服务器咨询问题、购买问题、可以联系我们客服 7271895 690624商祺云-阿里代理、景安代理、西部代理 刚开始学习和使用Linux系统的时候,大家都会遇到一个问题,那就是终端输入命令回显的时候中文显示乱码。其实乱码这个问题是由系统集成的字符集引起的,由于不能正确的使用相对应字符的字符集,因此OS不能识别出文字导致了乱码。如果你需要在Linux中…

    2019年1月14日
    3.7K00

发表回复

登录后才能评论
联系我们

联系我们

18838889666

在线咨询: QQ交谈

邮件:xinyun@88.com

工作时间:周一至周五,9:30-18:30,节假日休息

添加微信
添加微信
分享本页
返回顶部
---------官方优惠叠加渠道折扣:通过我们购买腾讯云/阿里云,价格更低,服务更优。更有专业配置指导与服务。微信同步:18838889666----