如何在Linux中使用Fio来测评硬盘性能

系统 Linux 开源
Fio(Flexible I/O Tester) 是一款由 Jens Axboe 开发的用于测评和压力/硬件验证的自由开源的软件。在这个教程,我们将使用 Ubuntu 16 ,你需要拥有这台电脑的 sudo 或 root 权限。我们将完整的进行安装和 Fio 的使用。

 [[239822]]

Fio(Flexible I/O Tester) 是一款由 Jens Axboe 开发的用于测评和压力/硬件验证的自由开源的软件。

它支持 19 种不同类型的 I/O 引擎 (sync、mmap、libaio、posixaio、SG v3、splice、null、network、 syslet、guasi、solarisaio,以及更多), I/O 优先级(针对较新的 Linux 内核),I/O 速度,fork 的任务或线程任务等等。它能够在块设备和文件上工作。

Fio 接受一种非常简单易于理解的文本格式的任务描述。软件默认包含了几个示例任务文件。 Fio 展示了所有类型的 I/O 性能信息,包括完整的 IO 延迟和百分比。

它被广泛的应用在非常多的地方,包括测评、QA,以及验证用途。它支持 Linux 、FreeBSD 、NetBSD、 OpenBSD、 OS X、 OpenSolaris、 AIX、 HP-UX、 Android 以及 Windows。

在这个教程,我们将使用 Ubuntu 16 ,你需要拥有这台电脑的 sudo 或 root 权限。我们将完整的进行安装和 Fio 的使用。

使用源码安装 Fio

我们要去克隆 GitHub 上的仓库。安装所需的依赖,然后我们将会从源码构建应用。首先,确保我们安装了 Git 。

  1. sudo apt-get install git

CentOS 用户可以执行下述命令:

  1. sudo yum install git

现在,我们切换到 /opt 目录,并从 Github 上克隆仓库:

  1. cd /opt
  2. git clone https://github.com/axboe/fio

你应该会看到下面这样的输出:

  1. Cloning into 'fio'...
  2. remote: Counting objects: 24819, done.
  3. remote: Compressing objects: 100% (44/44), done.
  4. remote: Total 24819 (delta 39), reused 62 (delta 32), pack-reused 24743
  5. Receiving objects: 100% (24819/24819), 16.07 MiB | 0 bytes/s, done.
  6. Resolving deltas: 100% (16251/16251), done.
  7. Checking connectivity... done.

现在,我们通过在 /opt 目录下输入下方的命令切换到 Fio 的代码目录:

  1. cd fio

***,我们可以使用下面的命令来使用 make 从源码构建软件:

  1. # ./configure
  2. # make
  3. # make install

在 Ubuntu 上安装 Fio

对于 Ubuntu 和 Debian 来说, Fio 已经在主仓库内。你可以很容易的使用类似 yumapt-get 的标准包管理器来安装 Fio。

对于 Ubuntu 和 Debian ,你只需要简单的执行下述命令:

  1. sudo apt-get install fio

对于 CentOS/Redhat 你只需要简单执行下述命令。

在 CentOS ,你可能在你能安装 Fio 前需要去安装 EPEL 仓库到你的系统中。你可以通过执行下述命令来安装它:

  1. sudo yum install epel-release -y

你可以执行下述命令来安装 Fio:

  1. sudo yum install fio -y

使用 Fio 进行磁盘性能测试

现在 Fio 已经安装到了你的系统中。现在是时候看一些如何使用 Fio 的例子了。我们将进行随机写、读和读写测试。

执行随机写测试

执行下面的命令来开始。这个命令将要同一时间执行两个进程,写入共计 4GB( 4 个任务 x 512MB = 2GB) 文件:

  1. sudo fio --name=randwrite --ioengine=libaio --iodepth=1 --rw=randwrite --bs=4k --direct=0 --size=512M --numjobs=2 --runtime=240 --group_reporting
  1. ...
  2. fio-2.2.10
  3. Starting 2 processes
  4.  
  5. randwrite: (groupid=0, jobs=2): err= 0: pid=7271: Sat Aug 5 13:28:44 2017
  6. write: io=1024.0MB, bw=2485.5MB/s, iops=636271, runt= 412msec
  7. slat (usec): min=1, max=268, avg= 1.79, stdev= 1.01
  8. clat (usec): min=0, max=13, avg= 0.20, stdev= 0.40
  9. lat (usec): min=1, max=268, avg= 2.03, stdev= 1.01
  10. clat percentiles (usec):
  11. | 1.00th=[ 0], 5.00th=[ 0], 10.00th=[ 0], 20.00th=[ 0],
  12. | 30.00th=[ 0], 40.00th=[ 0], 50.00th=[ 0], 60.00th=[ 0],
  13. | 70.00th=[ 0], 80.00th=[ 1], 90.00th=[ 1], 95.00th=[ 1],
  14. | 99.00th=[ 1], 99.50th=[ 1], 99.90th=[ 1], 99.95th=[ 1],
  15. | 99.99th=[ 1]
  16. lat (usec) : 2=99.99%, 4=0.01%, 10=0.01%, 20=0.01%
  17. cpu : usr=15.14%, sys=84.00%, ctx=8, majf=0, minf=26
  18. IO depths : 1=100.0%, 2=0.0%, 4=0.0%, 8=0.0%, 16=0.0%, 32=0.0%, >=64=0.0%
  19. submit : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.0%, >=64=0.0%
  20. complete : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.0%, >=64=0.0%
  21. issued : total=r=0/w=262144/d=0, short=r=0/w=0/d=0, drop=r=0/w=0/d=0
  22. latency : target=0, window=0, percentile=100.00%, depth=1
  23.  
  24. Run status group 0 (all jobs):
  25. WRITE: io=1024.0MB, aggrb=2485.5MB/s, minb=2485.5MB/s, maxb=2485.5MB/s, mint=412msec, maxt=412msec
  26.  
  27. Disk stats (read/write):
  28. sda: ios=0/0, merge=0/0, ticks=0/0, in_queue=0, util=0.00%

执行随机读测试

我们将要执行一个随机读测试,我们将会尝试读取一个随机的 2GB 文件。

  1.  
  2. sudo fio --name=randread --ioengine=libaio --iodepth=16 --rw=randread --bs=4k --direct=0 --size=512M --numjobs=4 --runtime=240 --group_reporting

你应该会看到下面这样的输出:

  1. ...
  2. fio-2.2.10
  3. Starting 4 processes
  4. randread: Laying out IO file(s) (1 file(s) / 512MB)
  5. randread: Laying out IO file(s) (1 file(s) / 512MB)
  6. randread: Laying out IO file(s) (1 file(s) / 512MB)
  7. randread: Laying out IO file(s) (1 file(s) / 512MB)
  8. Jobs: 4 (f=4): [r(4)] [100.0% done] [71800KB/0KB/0KB /s] [17.1K/0/0 iops] [eta 00m:00s]
  9. randread: (groupid=0, jobs=4): err= 0: pid=7586: Sat Aug 5 13:30:52 2017
  10. read : io=2048.0MB, bw=80719KB/s, iops=20179, runt= 25981msec
  11. slat (usec): min=72, max=10008, avg=195.79, stdev=94.72
  12. clat (usec): min=2, max=28811, avg=2971.96, stdev=760.33
  13. lat (usec): min=185, max=29080, avg=3167.96, stdev=798.91
  14. clat percentiles (usec):
  15. | 1.00th=[ 2192], 5.00th=[ 2448], 10.00th=[ 2576], 20.00th=[ 2736],
  16. | 30.00th=[ 2800], 40.00th=[ 2832], 50.00th=[ 2928], 60.00th=[ 3024],
  17. | 70.00th=[ 3120], 80.00th=[ 3184], 90.00th=[ 3248], 95.00th=[ 3312],
  18. | 99.00th=[ 3536], 99.50th=[ 6304], 99.90th=[15168], 99.95th=[18816],
  19. | 99.99th=[22912]
  20. bw (KB /s): min=17360, max=25144, per=25.05%, avg=20216.90, stdev=1605.65
  21. lat (usec) : 4=0.01%, 10=0.01%, 250=0.01%, 500=0.01%, 750=0.01%
  22. lat (usec) : 1000=0.01%
  23. lat (msec) : 2=0.01%, 4=99.27%, 10=0.44%, 20=0.24%, 50=0.04%
  24. cpu : usr=1.35%, sys=5.18%, ctx=524309, majf=0, minf=98
  25. IO depths : 1=0.1%, 2=0.1%, 4=0.1%, 8=0.1%, 16=100.0%, 32=0.0%, >=64=0.0%
  26. submit : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.0%, >=64=0.0%
  27. complete : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.1%, 32=0.0%, 64=0.0%, >=64=0.0%
  28. issued : total=r=524288/w=0/d=0, short=r=0/w=0/d=0, drop=r=0/w=0/d=0
  29. latency : target=0, window=0, percentile=100.00%, depth=16
  30.  
  31. Run status group 0 (all jobs):
  32. READ: io=2048.0MB, aggrb=80718KB/s, minb=80718KB/s, maxb=80718KB/s, mint=25981msec, maxt=25981msec
  33.  
  34. Disk stats (read/write):
  35. sda: ios=521587/871, merge=0/1142, ticks=96664/612, in_queue=97284, util=99.85%

***,我们想要展示一个简单的随机读-写测试来看一看 Fio 返回的输出类型。

读写性能测试

下述命令将会测试 USB Pen 驱动器 (/dev/sdc1) 的随机读写性能:

  1. sudo fio --randrepeat=1 --ioengine=libaio --direct=1 --gtod_reduce=1 --name=test --filename=random_read_write.fio --bs=4k --iodepth=64 --size=4G --readwrite=randrw --rwmixread=75

下面的内容是我们从上面的命令得到的输出:

  1. fio-2.2.10
  2. Starting 1 process
  3. Jobs: 1 (f=1): [m(1)] [100.0% done] [217.8MB/74452KB/0KB /s] [55.8K/18.7K/0 iops] [eta 00m:00s]
  4. test: (groupid=0, jobs=1): err= 0: pid=8475: Sat Aug 5 13:36:04 2017
  5. read : io=3071.7MB, bw=219374KB/s, iops=54843, runt= 14338msec
  6. write: io=1024.4MB, bw=73156KB/s, iops=18289, runt= 14338msec
  7. cpu : usr=6.78%, sys=20.81%, ctx=1007218, majf=0, minf=9
  8. IO depths : 1=0.1%, 2=0.1%, 4=0.1%, 8=0.1%, 16=0.1%, 32=0.1%, >=64=100.0%
  9. submit : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.0%, >=64=0.0%
  10. complete : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.1%, >=64=0.0%
  11. issued : total=r=786347/w=262229/d=0, short=r=0/w=0/d=0, drop=r=0/w=0/d=0
  12. latency : target=0, window=0, percentile=100.00%, depth=64
  13.  
  14. Run status group 0 (all jobs):
  15. READ: io=3071.7MB, aggrb=219374KB/s, minb=219374KB/s, maxb=219374KB/s, mint=14338msec, maxt=14338msec
  16. WRITE: io=1024.4MB, aggrb=73156KB/s, minb=73156KB/s, maxb=73156KB/s, mint=14338msec, maxt=14338msec
  17.  
  18. Disk stats (read/write):
  19. sda: ios=774141/258944, merge=1463/899, ticks=748800/150316, in_queue=900720, util=99.35%

 

我们希望你能喜欢这个教程并且享受接下来的内容,Fio 是一个非常有用的工具,并且我们希望你能在你下一次 Debugging 活动中使用到它。如果你喜欢这个文章,欢迎留下评论和问题。

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2019-09-16 19:00:48

Linux变量

2018-06-26 09:15:24

Linux命令history

2018-05-16 10:32:06

Linux命令find

2022-11-18 10:16:26

Linuxwc 命令

2022-10-25 09:07:28

Linuxxargs命令

2018-10-09 08:30:55

UbuntuLinuxRAR文件

2023-09-14 15:05:33

grep正则表达式

2019-08-01 08:00:04

AWS虚拟机Lightsail

2018-01-09 09:00:01

Linux命令文件压缩

2021-01-13 09:40:26

Linuxexport命令

2020-04-09 10:18:51

Bash循环Linux

2020-11-30 11:55:07

Docker命令Linux

2014-07-02 09:47:06

SwiftCocoaPods

2018-04-28 09:12:42

Linux

2018-06-25 11:58:23

Linuxparted磁盘分区

2022-05-25 08:41:48

Linuxfd 命令文件

2023-02-27 17:36:33

LinuxSIGINT信号

2021-07-20 10:00:28

Linuxgrep命令

2015-09-01 10:32:11

2015-09-01 14:29:33

点赞
收藏

51CTO技术栈公众号