一、环境说明:

此次演示是dellr620 物理服务器,系统为centos7.6 x86_64位
硬件相关的信息如下:

[root@mysql-redis scripts]# sh hw_msg1.sh 
+--------------------------------------------------------------+
| This Machine's Hyper-Threading is Enabled(recommend disable) |
+--------------------------------------------------------------+
Systembit    :    64
MEM info     :    20*4096 MB
Disk_totle   :    
Pro_SN_name  :    Product Name: PowerEdge R620 Serial Number: 5RV2962
System name  :    \S
Board_SN name:    Product Name: Serial Number:
CPU model    :    32  Intel(R) Xeon(R) CPU E5-2670 0 @ 2.60GHz
CPU_phy_num  :    2
CPU_core_num :    8
CPU_logic_num:    16
Netcard info :    Broadcom Inc. and subsidiaries NetXtreme BCM5720 Gigabit Ethernet PCIe
+++++++++++++++++++++++++++++++++++
<>
 Virtual Drive: 0 (Target Id: 0)
Name                :
RAID Level          : Primary-0, Secondary-0, RAID Level Qualifier-0
Size                : 893.75 GB
State               : Optimal
Strip Size          : 64 KB
Number Of Drives    : 1
--
Virtual Drive Information:
Virtual Drive: 1 (Target Id: 1)
Name                :
RAID Level          : Primary-0, Secondary-0, RAID Level Qualifier-0
Size                : 223.0 GB
State               : Optimal
Strip Size          : 64 KB
Number Of Drives    : 1
+++++++++++++++++++++++++++++++++++
<>
Device Id: 3
PD Type: SATA
Raw Size: 894.252 GB [0x6fc81ab0 Sectors]
Inquiry Data: 56AB609UKCDU        TOSHIBA Q300.                           SAFM12.3
Device Speed: 6.0Gb/s 
Drive Temperature : N/A
Device Id: 0
PD Type: SATA
Raw Size: 223.570 GB [0x1bf244b0 Sectors]
Inquiry Data: PHDV723500E8240AGN  INTEL SSDSC2BB240G7                     N2010112
Device Speed: 6.0Gb/s 
Drive Temperature :25C (77.00 F)

二、安装fio

1.redhat linux系统直接yum 安装
yum install fio.x86_64
centos7.6系统上直接yum 安装的话,默认的版本是fio.3.7

2.源码编译安装
为了测试异步io,需要安装libaio

yum install libaio-devel

wget  -P /data/soft http://github.com/axboe/fio/archive/fio-3.7.tar.gz
tar xf /data/soft/fio.3.7.tar.gz -C /usr/local/
cd /usr/local/fio.3.7
./configure
make && make install

三、重要参数介绍

Fio各个版本的参数不尽相同,这里只列出日常较为广发使用的重要参数
filename=/dev/sdb1 或者/data/soft/test1 : 指定测试硬盘名称或者测试文件名称(切忌选择系统设备测试,会导致系统奔溃的)
direct=1: 测试过程绕过机器自带的缓冲区,使得测试的结果更准确。
rw=randwrite: 随机写。 rw可取值:randwrite/randread/read/write/randrw/trim/randtrim/trimwrite ;分别是随机写,随机读,顺序读,顺序写,混合随机读写,
bs=16k : 单次I/O块大小为16KB,单次I/O大小对IOPS的影响比较大,一般来说要想得到最大的IOPS,bs越小越好。当然,这也和文件系统最小快的大小有关。一般linux下的文件分区最小快的大小为512B,1KB,2KB,4KB,8KB等可以根据文件系统类型进行选择。
size=5g : 测试文件大小为5GB
ioengine=libaio: I/O引擎使用libaio,libaio是异步的I/O引擎,一次提交一批I/O,然后等待这批I/O完成,这种方式减少了交互的次数,效率更好。FIO 至少支持13种不通的I/O引擎。sync,mmap,libaio,network等
iodepth=4 : I/O队列深度,主要是根据设备的并行度来调整。通常有两种I/O访问方式。也就是同步I/O,和异步I/O.同步I/O一次只能发送一个I/o请求,等待内核完成才可以返回。这对于单个线程来说iodepth总是小于1.想要iodepth大于1,可以通过多线程并发执行做到。异步I/O一次提交多个I/O请求。等I/O完成或者间隔一段时间收割一次。iodepth一般用在异步I/O模型(libaio),用于指定一次发起多少个I/O请求。Flash存储一般有多个并行的单元。支持多个I/O并发执行。较合适异步的I/O
-numjobs=4: 使用4个线程对硬盘设备进行压测 对于Raid设备,如raid1,raid5或者并行高的设备,可以考虑适当加大测试线程数-numjobs来测试。

runtime=1000: 测试时间为1000s.和参数size共同起作用,属于双限制,即达到任何一个限制都停止测试。

rwmixread=70: 在混合读写模式下,读占70%
group_reporting: 设置显示结果,指定group_reporting 将汇总每个进程的信息。
-name iops_randwrite: 改测试命名为 iops_randwrite
--output TestResult.log: 测试结果指定输出到文件TestResult.log 中

四、测试io性能

可以使用fio模拟测试各种不同类型的io请求,入随机写,顺序写,随机读,顺序读。混合随机读写

4.1随机写:

 time fio -rw=randwrite -bs=4k -runtime=60 -iodepth 1 -numjobs=4 -size=5G -filename /data/soft/test1 -ioengine libaio -direct=1 -group_reporting -name iops_randwrite   --output TestResult.log

命令介绍:
采用4个线程对 /data/soft/test1文件做持续时间为60s,队列深度为1,块大小为4kb的direct y异步随机写(libaio)测试,该测试命名为iops_randwrite.输出结果不安4个jobs展示,而是按照group 组汇总 ,这样得出的在此压力下从此文件系统的随机写的IOPS。对于Raid设备,如raid1,raid5或者并行高的设备,可以考虑适当加大测试线程数-numjobs来测试。
--output TestResult.log 输出到指定的日志

下面是随机写具体执行过程:


 [root@mysql-redis soft]# time fio -rw=randwrite -bs=4k -runtime=60 -iodepth 1 -numjobs=4 -size=5G -filename /data/soft/test1 -ioengine libaio -direct=1 -group_reporting -name iops_randwrite 
iops_randwrite: (g=0): rw=randwrite, bs=(R) 4096B-4096B, (W) 4096B-4096B, (T) 4096B-4096B, ioengine=libaio, iodepth=1
...
fio-3.7
Starting 4 processes
iops_randwrite: Laying out IO file (1 file / 5120MiB)
Jobs: 4 (f=4): [w(4)][100.0%][r=0KiB/s,w=68.2MiB/s][r=0,w=17.5k IOPS][eta 00m:00s]
iops_randwrite: (groupid=0, jobs=4): err= 0: pid=13505: Thu May 21 18:50:33 2020
  write: IOPS=39.2k, BW=153MiB/s (160MB/s)(9182MiB/60001msec)
    slat (usec): min=6, max=27813, avg=17.42, stdev=36.21
    clat (nsec): min=1177, max=123217k, avg=82183.17, stdev=323538.76
     lat (usec): min=53, max=123230, avg=99.84, stdev=325.69
    clat percentiles (usec):
     |  1.00th=[   47],  5.00th=[   51], 10.00th=[   57], 20.00th=[   62],
     | 30.00th=[   65], 40.00th=[   70], 50.00th=[   75], 60.00th=[   79],
     | 70.00th=[   84], 80.00th=[   91], 90.00th=[  103], 95.00th=[  117],
     | 99.00th=[  161], 99.50th=[  206], 99.90th=[  330], 99.95th=[  619],
     | 99.99th=[14615]
   bw (  KiB/s): min=17536, max=45304, per=25.12%, avg=39354.01, stdev=5145.44, samples=476
   iops        : min= 4384, max=11326, avg=9838.50, stdev=1286.36, samples=476
  lat (usec)   : 2=0.01%, 4=0.01%, 10=0.01%, 20=0.01%, 50=4.22%
  lat (usec)   : 100=84.07%, 250=11.50%, 500=0.12%, 750=0.03%, 1000=0.01%
  lat (msec)   : 2=0.01%, 4=0.01%, 10=0.01%, 20=0.03%, 50=0.01%
  lat (msec)   : 250=0.01%
  cpu          : usr=4.33%, sys=19.34%, ctx=2824889, majf=0, minf=1185
  IO depths    : 1=100.0%, 2=0.0%, 4=0.0%, 8=0.0%, 16=0.0%, 32=0.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.0%, 64=0.0%, >=64=0.0%
     issued rwts: total=0,2350467,0,0 short=0,0,0,0 dropped=0,0,0,0
     latency   : target=0, window=0, percentile=100.00%, depth=1

Run status group 0 (all jobs):
  WRITE: bw=153MiB/s (160MB/s), 153MiB/s-153MiB/s (160MB/s-160MB/s), io=9182MiB (9628MB), run=60001-60001msec

Disk stats (read/write):
  sda: ios=0/2349456, merge=0/0, ticks=0/167181, in_queue=166516, util=96.46%

real    1m0.706s
user    0m11.167s
sys 0m47.017s

4.2随机读:

time fio -readonly -rw=randread -bs=4k -runtime=60 -iodepth 1 -numjobs=2  -filename /data/soft/test2 -ioengine libaio -direct=1 -group_reporting -name iops_randread 

关于命令参数说明:
命令介绍:采用2个线程对 /data/soft/test1文件做持续时间为60s,队列深度为1,块大小为4kb的direct y异步随机读(libaio)测试,该测试命名为iops_randread.输出结果不安2个jobs展示,而是按照group 组汇总 ,这样得出的在此压力下从此文件系统的随机读的IOPS

下面是随机读具体执行过程:

 [root@mysql-redis39 ~]# time fio -readonly -rw=randread -bs=4k -runtime=60 -iodepth 1 -numjobs=2  -filename /data/soft/test2 -ioengine libaio -direct=1 -group_reporting -name iops_randread 
iops_randread: (g=0): rw=randread, bs=(R) 4096B-4096B, (W) 4096B-4096B, (T) 4096B-4096B, ioengine=libaio, iodepth=1
...
fio-3.7
Starting 2 processes
Jobs: 2 (f=2): [r(2)][100.0%][r=36.7MiB/s,w=0KiB/s][r=9389,w=0 IOPS][eta 00m:00s]
iops_randread: (groupid=0, jobs=2): err= 0: pid=24566: Fri May 22 06:21:46 2020
   read: IOPS=9358, BW=36.6MiB/s (38.3MB/s)(2193MiB/60001msec)
    slat (usec): min=7, max=1480, avg=23.09, stdev= 8.09
    clat (usec): min=8, max=123984, avg=185.97, stdev=570.65
     lat (usec): min=136, max=123999, avg=209.50, stdev=570.70
    clat percentiles (usec):
     |  1.00th=[  139],  5.00th=[  141], 10.00th=[  145], 20.00th=[  169],
     | 30.00th=[  174], 40.00th=[  178], 50.00th=[  182], 60.00th=[  188],
     | 70.00th=[  198], 80.00th=[  204], 90.00th=[  212], 95.00th=[  219],
     | 99.00th=[  255], 99.50th=[  273], 99.90th=[  322], 99.95th=[  537],
     | 99.99th=[ 1549]
   bw (  KiB/s): min=13824, max=19616, per=49.99%, avg=18713.87, stdev=1060.66, samples=238
   iops        : min= 3456, max= 4904, avg=4678.43, stdev=265.16, samples=238
  lat (usec)   : 10=0.01%, 100=0.01%, 250=98.87%, 500=1.08%, 750=0.02%
  lat (usec)   : 1000=0.01%
  lat (msec)   : 2=0.02%, 4=0.01%, 20=0.01%, 250=0.01%
  cpu          : usr=4.11%, sys=15.44%, ctx=561546, majf=0, minf=498
  IO depths    : 1=100.0%, 2=0.0%, 4=0.0%, 8=0.0%, 16=0.0%, 32=0.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.0%, 64=0.0%, >=64=0.0%
     issued rwts: total=561503,0,0,0 short=0,0,0,0 dropped=0,0,0,0
     latency   : target=0, window=0, percentile=100.00%, depth=1

Run status group 0 (all jobs):
   READ: bw=36.6MiB/s (38.3MB/s), 36.6MiB/s-36.6MiB/s (38.3MB/s-38.3MB/s), io=2193MiB (2300MB), run=60001-60001msec

Disk stats (read/write):
  sda: ios=560393/2, merge=0/0, ticks=102314/0, in_queue=101910, util=97.80%

real    1m0.706s
user    0m5.649s
sys 0m19.196s

以上需要关注的指标:
read: IOPS=9358, BW=36.6MiB/s (38.3MB/s)(2193MiB/60001msec) io=2193MiB (2300MB) 这些参数可以了解到iops和通途量
lat (usec): min=136, max=123999, avg=209.50, stdev=570.70 这些参数也要注意:io延迟平均在209.5微妙。

4.3顺序写:

time fio -rw=write -bs=1m -runtime=60 -iodepth 1 -numjobs=5 -size=5G -filename /data/soft/test3 -ioengine libaio -direct=1 -group_reporting -name bw_write

说明:采用4个线程对/data/soft/test3文件做持续60s,队列深度为1的块大小为1M的direct异步顺序写(libaio)压力测试该测试命名为bw_write.输出结果不安4个job分别展示,而是按照group汇总展示。

[root@mysql-redis ~]# time fio -rw=write -bs=1m -runtime=60 -iodepth 1 -numjobs=5 -size=5G -filename /data/soft/test3 -ioengine libaio -direct=1 -group_reporting -name bw_write  
bw_write: (g=0): rw=write, bs=(R) 1024KiB-1024KiB, (W) 1024KiB-1024KiB, (T) 1024KiB-1024KiB, ioengine=libaio, iodepth=1
...
fio-3.7
Starting 5 processes
bw_write: Laying out IO file (1 file / 5120MiB)
Jobs: 5 (f=5): [W(5)][100.0%][r=0KiB/s,w=184MiB/s][r=0,w=184 IOPS][eta 00m:00s]
bw_write: (groupid=0, jobs=5): err= 0: pid=26278: Fri May 22 06:44:38 2020
  write: IOPS=319, BW=320MiB/s (335MB/s)(18.7GiB/60009msec)
    slat (usec): min=56, max=303, avg=140.02, stdev=29.86
    clat (msec): min=3, max=1092, avg=15.49, stdev=67.68
     lat (msec): min=3, max=1093, avg=15.63, stdev=67.68

4.4顺序读:

time fio -readonly -rw=read -bs=1m -runtime=60 -iodepth 1 -numjobs=2  -filename /data/soft/test2 -ioengine libaio -direct=1 -group_reporting -name bw_read 
[root@mysql-redis ~]# time fio -readonly -rw=read -bs=1m -runtime=60 -iodepth 1 -numjobs=2  -filename /data/soft/test2 -ioengine libaio -direct=1 -group_reporting -name bw_read 
bw_read: (g=0): rw=read, bs=(R) 1024KiB-1024KiB, (W) 1024KiB-1024KiB, (T) 1024KiB-1024KiB, ioengine=libaio, iodepth=1
...
fio-3.7
Starting 2 processes
Jobs: 2 (f=2): [R(2)][100.0%][r=259MiB/s,w=0KiB/s][r=259,w=0 IOPS][eta 00m:00s]
bw_read: (groupid=0, jobs=2): err= 0: pid=26789: Fri May 22 06:51:01 2020
   read: IOPS=255, BW=256MiB/s (268MB/s)(10.0GiB/40034msec)
    slat (usec): min=95, max=1149, avg=245.64, stdev=42.23
    clat (msec): min=4, max=130, avg= 7.57, stdev= 2.98
     lat (msec): min=4, max=130, avg= 7.81, stdev= 2.98

4.5混合读写

time fio  -rw=randrw  -rwmixread=70 -bs=16k -runtime=60 -iodepth 1 -numjobs=2  -filename /data/soft/test2 -ioengine libaio -direct=1 -group_reporting -name iops_randrw

命令介绍:
2个线程对/data/soft/test2 文件做持续时间为60s,队列深度为1,块大小为16kb的direct异步混合读写的(libaio)压力测试,读写比伪7:3,测试被命名为iops_randrw

rwmixwrite=30 意思是在混合读写的模式下,写占30%。
-rwmixread=70 意思是在混合读写的模式下,读占70%。

混合读写具体输出结果:


[root@mysql-redis ~]# time fio  -rw=randrw  -rwmixread=70 -bs=16k -runtime=60 -iodepth 1 -numjobs=2  -filename /data/soft/test2 -ioengine libaio -direct=1 -group_reporting -name iops_randrw

iops_randrw: (g=0): rw=randrw, bs=(R) 16.0KiB-16.0KiB, (W) 16.0KiB-16.0KiB, (T) 16.0KiB-16.0KiB, ioengine=libaio, iodepth=1
...
fio-3.7
Starting 2 processes
Jobs: 2 (f=2): [m(2)][100.0%][r=62.0MiB/s,w=27.2MiB/s][r=4030,w=1740 IOPS][eta 00m:00s]
iops_randrw: (groupid=0, jobs=2): err= 0: pid=27095: Fri May 22 06:55:08 2020
   read: IOPS=3931, BW=61.4MiB/s (64.4MB/s)(3686MiB/60001msec)
    slat (usec): min=8, max=6353, avg=36.20, stdev=19.77
    clat (nsec): min=1648, max=123466k, avg=346175.56, stdev=725094.33
     lat (usec): min=12, max=123516, avg=382.99, stdev=725.55
    clat percentiles (usec):
     |  1.00th=[  215],  5.00th=[  241], 10.00th=[  255], 20.00th=[  277],
     | 30.00th=[  293], 40.00th=[  310], 50.00th=[  322], 60.00th=[  334],
     | 70.00th=[  351], 80.00th=[  375], 90.00th=[  412], 95.00th=[  449],
     | 99.00th=[ 1221], 99.50th=[ 1467], 99.90th=[ 1631], 99.95th=[ 1827],
     | 99.99th=[16712]
   bw (  KiB/s): min=23328, max=33792, per=49.97%, avg=31431.39, stdev=1649.11, samples=238
   iops        : min= 1458, max= 2112, avg=1964.44, stdev=103.06, samples=238
  write: IOPS=1686, BW=26.4MiB/s (27.6MB/s)(1581MiB/60001msec)
    slat (usec): min=12, max=2005, avg=42.06, stdev=16.09
    clat (usec): min=3, max=123270, avg=225.73, stdev=432.84
     lat (usec): min=86, max=123320, avg=268.44, stdev=433.42
    clat percentiles (usec):
     |  1.00th=[   78],  5.00th=[   85], 10.00th=[  100], 20.00th=[  129],
     | 30.00th=[  149], 40.00th=[  174], 50.00th=[  202], 60.00th=[  233],
     | 70.00th=[  265], 80.00th=[  306], 90.00th=[  359], 95.00th=[  408],
     | 99.00th=[  510], 99.50th=[ 1090], 99.90th=[ 1549], 99.95th=[ 1614],
     | 99.99th=[ 5080]
   bw (  KiB/s): min= 9152, max=15329, per=49.97%, avg=13484.37, stdev=892.91, samples=238
   iops        : min=  572, max=  958, avg=842.76, stdev=55.80, samples=238
  lat (usec)   : 2=0.01%, 4=0.01%, 10=0.01%, 50=0.01%, 100=3.06%
  lat (usec)   : 250=22.22%, 500=72.91%, 750=0.76%, 1000=0.05%
  lat (msec)   : 2=0.96%, 4=0.01%, 10=0.01%, 20=0.01%, 50=0.01%
  lat (msec)   : 250=0.01%
  cpu          : usr=4.64%, sys=15.91%, ctx=346233, majf=0, minf=266
  IO depths    : 1=100.0%, 2=0.0%, 4=0.0%, 8=0.0%, 16=0.0%, 32=0.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.0%, 64=0.0%, >=64=0.0%
     issued rwts: total=235884,101198,0,0 short=0,0,0,0 dropped=0,0,0,0
     latency   : target=0, window=0, percentile=100.00%, depth=1

Run status group 0 (all jobs):
   READ: bw=61.4MiB/s (64.4MB/s), 61.4MiB/s-61.4MiB/s (64.4MB/s-64.4MB/s), io=3686MiB (3865MB), run=60001-60001msec
  WRITE: bw=26.4MiB/s (27.6MB/s), 26.4MiB/s-26.4MiB/s (27.6MB/s-27.6MB/s), io=1581MiB (1658MB), run=60001-60001msec

Disk stats (read/write):
  sda: ios=274477/101294, merge=0/0, ticks=88860/19119, in_queue=107576, util=95.82%

real    1m0.690s
user    0m6.300s
sys 0m19.718s

4.6SSD性能测试配置文件

配置文件内容如下:

[root@mysql-redis scripts]# cat /data/soft/ssd-test.fio 
##2020-05-24
[global]
bs=4k
ioengine=libaio
iodepth=4
numjobs=1
group_reporting
size=5g
direct=1
runtime=60
directory=/data/soft
filename=ssd.test.file
#inflate-log=/data/soft/TestResult.log
#output=/data/soft/TestResult.log
[seq-read]
name=iops_seqread
rw=read
stonewall

[rand-read]
name=iops_randread
rw=randread
stonewall

[seq-write]
name=iops_seqwrite
rw=write
stonewall

[rand-write]
name=iops_randwrite
rw=randwrite
stonewall

[randrw]
name=iops_randrw
rwmixread=70
rw=randrw
stonewall

下面是fio测试指定配置文件输出的内容:

[root@mysql-redis soft]# fio ssd-test.fio 
iops_seqread: (g=0): rw=read, bs=(R) 4096B-4096B, (W) 4096B-4096B, (T) 4096B-4096B, ioengine=libaio, iodepth=4
iops_randread: (g=1): rw=randread, bs=(R) 4096B-4096B, (W) 4096B-4096B, (T) 4096B-4096B, ioengine=libaio, iodepth=4
iops_seqwrite: (g=2): rw=write, bs=(R) 4096B-4096B, (W) 4096B-4096B, (T) 4096B-4096B, ioengine=libaio, iodepth=4
iops_randwrite: (g=3): rw=randwrite, bs=(R) 4096B-4096B, (W) 4096B-4096B, (T) 4096B-4096B, ioengine=libaio, iodepth=4
iops_randrw: (g=4): rw=randrw, bs=(R) 4096B-4096B, (W) 4096B-4096B, (T) 4096B-4096B, ioengine=libaio, iodepth=4
fio-3.7
Starting 5 processes
iops_seqread: Laying out IO file (1 file / 5120MiB)
Jobs: 1 (f=1): [_(4),m(1)][90.5%][r=47.8MiB/s,w=20.7MiB/s][r=12.2k,w=5308 IOPS][eta 00m:21s]     
iops_seqread: (groupid=0, jobs=1): err= 0: pid=2142: Sun May 24 20:06:20 2020
   read: IOPS=57.5k, BW=225MiB/s (236MB/s)(5120MiB/22782msec)
    slat (usec): min=3, max=1943, avg= 5.13, stdev= 2.21
    clat (usec): min=25, max=12467, avg=63.13, stdev=202.65
     lat (usec): min=40, max=12472, avg=68.41, stdev=202.72
    clat percentiles (usec):
     |  1.00th=[   45],  5.00th=[   53], 10.00th=[   55], 20.00th=[   56],
     | 30.00th=[   56], 40.00th=[   56], 50.00th=[   57], 60.00th=[   57],
     | 70.00th=[   57], 80.00th=[   58], 90.00th=[   59], 95.00th=[   62],
     | 99.00th=[   69], 99.50th=[   79], 99.90th=[ 2073], 99.95th=[ 5080],
     | 99.99th=[10814]
   bw (  KiB/s): min=43579, max=193812, per=75.80%, avg=174446.82, stdev=47419.87, samples=45
   iops        : min=10894, max=48453, avg=43611.36, stdev=11855.06, samples=45
  lat (usec)   : 50=3.39%, 100=96.25%, 250=0.08%, 500=0.07%, 750=0.04%
  lat (usec)   : 1000=0.02%
  lat (msec)   : 2=0.06%, 4=0.04%, 10=0.05%, 20=0.01%
  cpu          : usr=19.83%, sys=39.29%, ctx=1222141, majf=0, minf=114
  IO depths    : 1=0.1%, 2=0.1%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.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.0%, 64=0.0%, >=64=0.0%
     issued rwts: total=1310720,0,0,0 short=0,0,0,0 dropped=0,0,0,0
     latency   : target=0, window=0, percentile=100.00%, depth=4
iops_randread: (groupid=1, jobs=1): err= 0: pid=2170: Sun May 24 20:06:20 2020
   read: IOPS=21.7k, BW=84.9MiB/s (89.0MB/s)(5094MiB/60001msec)
    slat (usec): min=3, max=1068, avg=12.62, stdev= 6.14
    clat (usec): min=42, max=38568, avg=167.76, stdev=315.76
     lat (usec): min=62, max=38588, avg=180.75, stdev=316.07
    clat percentiles (usec):
     |  1.00th=[  130],  5.00th=[  135], 10.00th=[  137], 20.00th=[  141],
     | 30.00th=[  143], 40.00th=[  147], 50.00th=[  151], 60.00th=[  155],
     | 70.00th=[  161], 80.00th=[  172], 90.00th=[  192], 95.00th=[  206],
     | 99.00th=[  251], 99.50th=[  273], 99.90th=[ 3982], 99.95th=[ 7308],
     | 99.99th=[14091]
   bw (  KiB/s): min= 5397, max=74196, per=79.00%, avg=68682.74, stdev=15713.88, samples=119
   iops        : min= 1349, max=18549, avg=17170.32, stdev=3928.48, samples=119
  lat (usec)   : 50=0.01%, 100=0.02%, 250=98.94%, 500=0.82%, 750=0.02%
  lat (usec)   : 1000=0.02%
  lat (msec)   : 2=0.03%, 4=0.04%, 10=0.07%, 20=0.02%, 50=0.01%
  cpu          : usr=11.52%, sys=37.46%, ctx=668232, majf=0, minf=319
  IO depths    : 1=0.1%, 2=0.1%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.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.0%, 64=0.0%, >=64=0.0%
     issued rwts: total=1304064,0,0,0 short=0,0,0,0 dropped=0,0,0,0
     latency   : target=0, window=0, percentile=100.00%, depth=4
iops_seqwrite: (groupid=2, jobs=1): err= 0: pid=2231: Sun May 24 20:06:20 2020
  write: IOPS=47.1k, BW=184MiB/s (193MB/s)(5120MiB/27848msec)
    slat (usec): min=4, max=139, avg= 7.50, stdev= 2.96
    clat (usec): min=27, max=15374, avg=76.14, stdev=278.53
     lat (usec): min=49, max=15381, avg=83.78, stdev=279.26
    clat percentiles (usec):
     |  1.00th=[   56],  5.00th=[   59], 10.00th=[   60], 20.00th=[   61],
     | 30.00th=[   62], 40.00th=[   64], 50.00th=[   65], 60.00th=[   67],
     | 70.00th=[   68], 80.00th=[   71], 90.00th=[   73], 95.00th=[   74],
     | 99.00th=[   81], 99.50th=[   89], 99.90th=[ 3326], 99.95th=[ 3392],
     | 99.99th=[15139]
   bw (  KiB/s): min= 3769, max=175262, per=80.83%, avg=152166.87, stdev=43009.10, samples=55
   iops        : min=  942, max=43815, avg=38041.35, stdev=10752.22, samples=55
  lat (usec)   : 50=0.24%, 100=99.43%, 250=0.07%, 500=0.01%, 750=0.01%
  lat (usec)   : 1000=0.01%
  lat (msec)   : 2=0.01%, 4=0.21%, 10=0.01%, 20=0.03%
  cpu          : usr=11.79%, sys=43.48%, ctx=652945, majf=0, minf=95
  IO depths    : 1=0.1%, 2=0.1%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.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.0%, 64=0.0%, >=64=0.0%
     issued rwts: total=0,1310720,0,0 short=0,0,0,0 dropped=0,0,0,0
     latency   : target=0, window=0, percentile=100.00%, depth=4
iops_randwrite: (groupid=3, jobs=1): err= 0: pid=2262: Sun May 24 20:06:20 2020
  write: IOPS=47.2k, BW=185MiB/s (194MB/s)(5120MiB/27743msec)
    slat (usec): min=4, max=415, avg= 7.49, stdev= 2.82
    clat (usec): min=26, max=21032, avg=75.63, stdev=276.91
     lat (usec): min=48, max=21058, avg=83.27, stdev=277.60
    clat percentiles (usec):
     |  1.00th=[   56],  5.00th=[   60], 10.00th=[   60], 20.00th=[   62],
     | 30.00th=[   62], 40.00th=[   64], 50.00th=[   65], 60.00th=[   67],
     | 70.00th=[   68], 80.00th=[   70], 90.00th=[   73], 95.00th=[   74],
     | 99.00th=[   80], 99.50th=[   86], 99.90th=[ 3326], 99.95th=[ 3392],
     | 99.99th=[15139]
   bw (  KiB/s): min= 3175, max=142274, per=68.21%, avg=128901.20, stdev=33671.41, samples=55
   iops        : min=  793, max=35568, avg=32224.95, stdev=8417.81, samples=55
  lat (usec)   : 50=0.21%, 100=99.50%, 250=0.04%, 500=0.01%, 750=0.01%
  lat (usec)   : 1000=0.01%
  lat (msec)   : 2=0.01%, 4=0.20%, 10=0.01%, 20=0.02%, 50=0.01%
  cpu          : usr=12.97%, sys=43.05%, ctx=654916, majf=0, minf=258
  IO depths    : 1=0.1%, 2=0.1%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.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.0%, 64=0.0%, >=64=0.0%
     issued rwts: total=0,1310720,0,0 short=0,0,0,0 dropped=0,0,0,0
     latency   : target=0, window=0, percentile=100.00%, depth=4
iops_randrw: (groupid=4, jobs=1): err= 0: pid=2292: Sun May 24 20:06:20 2020
   read: IOPS=11.3k, BW=44.3MiB/s (46.5MB/s)(2659MiB/60001msec)
    slat (usec): min=4, max=594, avg=13.08, stdev= 6.88
    clat (usec): min=61, max=45073, avg=244.45, stdev=441.39
     lat (usec): min=134, max=45115, avg=257.84, stdev=441.61
    clat percentiles (usec):
     |  1.00th=[  137],  5.00th=[  143], 10.00th=[  151], 20.00th=[  176],
     | 30.00th=[  190], 40.00th=[  202], 50.00th=[  212], 60.00th=[  221],
     | 70.00th=[  233], 80.00th=[  258], 90.00th=[  330], 95.00th=[  359],
     | 99.00th=[  474], 99.50th=[ 1270], 99.90th=[ 6521], 99.95th=[10028],
     | 99.99th=[17695]
   bw (  KiB/s): min= 3072, max=51824, per=99.92%, avg=45336.55, stdev=11250.66, samples=119
   iops        : min=  768, max=12958, avg=11334.12, stdev=2812.66, samples=119
  write: IOPS=4860, BW=18.0MiB/s (19.9MB/s)(1139MiB/60001msec)
    slat (usec): min=6, max=874, avg=16.94, stdev= 7.42
    clat (usec): min=40, max=31265, avg=192.80, stdev=413.19
     lat (usec): min=56, max=31306, avg=210.09, stdev=413.32
    clat percentiles (usec):
     |  1.00th=[   52],  5.00th=[   58], 10.00th=[   62], 20.00th=[   78],
     | 30.00th=[  145], 40.00th=[  169], 50.00th=[  188], 60.00th=[  202],
     | 70.00th=[  212], 80.00th=[  227], 90.00th=[  251], 95.00th=[  277],
     | 99.00th=[  619], 99.50th=[ 1205], 99.90th=[ 5997], 99.95th=[ 9634],
     | 99.99th=[16581]
   bw (  KiB/s): min= 1184, max=22176, per=99.94%, avg=19428.64, stdev=4847.41, samples=119
   iops        : min=  296, max= 5544, avg=4857.13, stdev=1211.85, samples=119
  lat (usec)   : 50=0.12%, 100=7.22%, 250=74.36%, 500=17.22%, 750=0.24%
  lat (usec)   : 1000=0.10%
  lat (msec)   : 2=0.52%, 4=0.06%, 10=0.11%, 20=0.04%, 50=0.01%
  cpu          : usr=7.88%, sys=29.46%, ctx=340101, majf=0, minf=374
  IO depths    : 1=0.1%, 2=0.1%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.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.0%, 64=0.0%, >=64=0.0%
     issued rwts: total=680630,291634,0,0 short=0,0,0,0 dropped=0,0,0,0
     latency   : target=0, window=0, percentile=100.00%, depth=4

Run status group 0 (all jobs):
   READ: bw=225MiB/s (236MB/s), 225MiB/s-225MiB/s (236MB/s-236MB/s), io=5120MiB (5369MB), run=22782-22782msec

Run status group 1 (all jobs):
   READ: bw=84.9MiB/s (89.0MB/s), 84.9MiB/s-84.9MiB/s (89.0MB/s-89.0MB/s), io=5094MiB (5341MB), run=60001-60001msec

Run status group 2 (all jobs):
  WRITE: bw=184MiB/s (193MB/s), 184MiB/s-184MiB/s (193MB/s-193MB/s), io=5120MiB (5369MB), run=27848-27848msec

Run status group 3 (all jobs):
  WRITE: bw=185MiB/s (194MB/s), 185MiB/s-185MiB/s (194MB/s-194MB/s), io=5120MiB (5369MB), run=27743-27743msec

Run status group 4 (all jobs):
   READ: bw=44.3MiB/s (46.5MB/s), 44.3MiB/s-44.3MiB/s (46.5MB/s-46.5MB/s), io=2659MiB (2788MB), run=60001-60001msec
  WRITE: bw=18.0MiB/s (19.9MB/s), 18.0MiB/s-18.0MiB/s (19.9MB/s-19.9MB/s), io=1139MiB (1195MB), run=60001-60001msec

Disk stats (read/write):
  sda: ios=3294785/2912828, merge=0/3, ticks=430527/238028, in_queue=666582, util=99.09%
[root@mysql-redis soft]# 

五、总结

关于fio测试硬盘的建议:
一、建议使用顺序I/O和较大的blocksize 来测试设备的通吐量和延迟
二、建议使用随机I/O和较小的blocksize来测试设备的IOPS和延迟
三、在配置numjobs和iodepth 测试底层存储性能时,建议要深入了解应用到底采用的是同步的io还是异步的io(是多进程并发i/o请求还是一次提交一批的i/o的请求)
提示:对fio压测 磁盘性能感兴趣的话,可以参考下ezfio(直接在github.com上搜索ezfio)
重要提示:fio是 支持对裸设备直接进行I/O测试的,在测试裸设备时,一定要避开系统所在的裸设备,否则会导致系统奔溃。
例如:

[root@mysql-redis soft]# df -h / /boot 
文件系统        容量  已用  可用 已用% 挂载点
/dev/sdb5       207G  7.5G  200G    4% /
/dev/sdb1       297M  120M  177M   41% /boot

/dev/sdb /dev/sdb5 /dev/sdb1 这些设备是绝对禁止进行fio测试的,
同时在测试其他的设备裸设备时,一定要提前确定好此裸设备上是否有重要 的数据,一定要重要的设备提前做好备份。

以上就是我这边对fio测试硬盘的简单学习总结,仅供参考,如有网友直接复制应用造成损失,本博文不负担任何责任。
参考文档:
http://www.ssdfans.com/?p=6087
https://linux.die.net/man/1/fio
https://blog.csdn.net/don_chiang709/article/details/92628623