fio磁盘io压测

九月1年前技术文章483

fio tar包地址:https://brick.kernel.dk/snaps/

yum 安装gcc、fio使用到的ibaio-devel 引擎

yum install -y gcc
yum install -y libaio-devel

解压fio tar包

tar -zxvf fio-2.6.tar.gz

进入目录执行命令

cd fio-2.1.10
./configure
make
make install

图1.png

fio的参数配置

filename=/bdata/test.big 测试文件名称,通常选择需要测试的盘所在的目录。
direct=1 测试过程绕过机器自带的buffer。使测试结果更真实。
rw=randwrite 测试随机写的I/O
rw=randrw 测试随机写和读的I/O
bs=4k 单次io的块文件大小为4k
size=2g 本次的测试文件大小为2g,以每次4k的io进行测试。
numjobs=64 本次的测试线程为64.   【建议设置为CPU的CORE数量一致】
runtime=20 测试时间为20秒,如果不写则一直将2g文件分4k每次写完为止。
ioengine=psync io引擎使用pync方式 ,此外还有libaio 异步方式。
rwmixwrite=30 在混合读写的模式下,写占30%
group_reporting 关于显示结果的,汇总每个进程的信息。
sync=1 设置异步io
fsync=1 一个io就同步数据


使用dd创建测试文件

# 通常在需要测试的那个磁盘下面生成一个这种测试用的大文件,注意设置文件大小,防止抢占其他文件磁盘空间
dd if=/dev/zero of=/data/test.big bs=4k count=524288

图2.png

测试随机写

 ./fio -direct=1 -iodepth=32 -rw=randwrite -ioengine=libaio -bs=4k -numjobs=4 -time_based=1 -runtime=1000 -group_reporting -filename=/data/test.big -name=test

结果

test: (g=0): rw=randwrite, bs=4K-4K/4K-4K/4K-4K, ioengine=libaio, iodepth=32
...
fio-2.6
Starting 4 processes
Jobs: 4 (f=4): [w(4)] [100.0% done] [0KB/61766KB/0KB /s] [0/15.5K/0 iops] [eta 00m:00s]
test: (groupid=0, jobs=4): err= 0: pid=25826: Fri Aug 12 20:17:55 2022
  write: io=51430MB, bw=52664KB/s, iops=13165, runt=1000007msec
    slat (usec): min=6, max=6078, avg=16.08, stdev=12.46
    clat (usec): min=350, max=1163.8K, avg=9690.77, stdev=19697.17
     lat (usec): min=788, max=1163.9K, avg=9708.57, stdev=19697.22
    clat percentiles (usec):
     |  1.00th=[ 1560],  5.00th=[ 2640], 10.00th=[ 3632], 20.00th=[ 4576],
     | 30.00th=[ 5216], 40.00th=[ 5920], 50.00th=[ 6880], 60.00th=[ 7968],
     | 70.00th=[ 9024], 80.00th=[10048], 90.00th=[11840], 95.00th=[14400],
     | 99.00th=[120320], 99.50th=[177152], 99.90th=[211968], 99.95th=[222208],
     | 99.99th=[444416]
    bw (KB  /s): min=    5, max=22048, per=25.06%, avg=13199.60, stdev=2872.94
    lat (usec) : 500=0.01%, 750=0.01%, 1000=0.02%
    lat (msec) : 2=2.47%, 4=10.38%, 10=66.26%, 20=17.84%, 50=1.38%
    lat (msec) : 100=0.52%, 250=1.11%, 500=0.02%, 750=0.01%, 1000=0.01%
    lat (msec) : 2000=0.01%
  cpu          : usr=4.18%, sys=9.90%, ctx=9406402, majf=0, minf=127
  IO depths    : 1=0.1%, 2=0.1%, 4=0.1%, 8=0.1%, 16=0.1%, 32=100.0%, >=64=0.0%
     submit    : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.0%, >=64=0.0%
     complete  : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.1%, 64=0.0%, >=64=0.0%
     issued    : total=r=0/w=13165990/d=0, short=r=0/w=0/d=0, drop=r=0/w=0/d=0
     latency   : target=0, window=0, percentile=100.00%, depth=32

Run status group 0 (all jobs):
  WRITE: io=51430MB, aggrb=52663KB/s, minb=52663KB/s, maxb=52663KB/s, mint=1000007msec, maxt=1000007msec

Disk stats (read/write):
  vda: ios=8/13169214, merge=0/202, ticks=56/127225123, in_queue=125756338, util=98.79%

测试随机读写:

./fio --filename=/data/test.big -iodepth=64 -ioengine=libaio -direct=1 -rw=randwrite -bs=4k -size=2G -numjobs=64 -runtime=1000 -group_reporting -name=test-rand-write

扩展:使用hdparm测试io读

 hdparm -t --direct /dev/vda2

图3.png


相关文章

压测实操--kafka broker压测方案

压测实操--kafka broker压测方案

环境信息:操作系统centos7.9,kafka版本为hdp集群中的2.0版本。kafka broker参数num.replica.fetchers:副本抓取的相应参数,如果发生ISR频繁进出的情况或...

Hive压测之开源Hive基准测试工具(hive-testbench-hive14)

Hive压测之开源Hive基准测试工具(hive-testbench-hive14)

此文章禁止转载概述Hive基准测试工具工具,可用来造数测试Hive基本性能。TPC-DS:提供一个公平和诚实的业务和数据模型,99个案例TPC-H:面向商品零售业的决策支持系统测试基准,定义了8张表,...

压测实操--kafka-consumer压测方案

压测实操--kafka-consumer压测方案

环境信息:操作系统centos7.9,kafka版本为hdp集群中的2.0版本。Consumer相关参数使用Kafka自带的kafka-consumer-perf-test.sh脚本进行压测,该脚本参...

压测实操--TestDFSIO压测hdfs读写方案

压测实操--TestDFSIO压测hdfs读写方案

TestDFSIO主要是对hdfs的I/O性能进行测试,通过使用MapReduce作业来完成测试,作为并行读写文件进行I/O性能测试。每个map任务用于读或写每个文件,map的输出用于收集与处理文件相...

IDC:疫情下,第三方云管理服务市场逆势增长!

IDC:疫情下,第三方云管理服务市场逆势增长!

IDC预测,中国第三方云管理服务在2019年到2023年间将保持54.7%的增长率,2023年市场规模预计达到32.1亿美元。2019年第三方云管理服务市场呈现出如下特点:云管理服务成为众多服务商的战...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。