一、FIO工具安装:

1、FIO地址:

官网地址:http://freecode.com/projects/fio/

源码安装包:http://brick.kernel.dk/snaps/fio-2.1.10.tar.gz

2、安装FIO工具

[root@localhost ~]#rpm –qa|grep fio
[root@lh fio-2.1.10]# ./configure
[root@lh fio-2.1.10]# make
[root@lh fio-2.1.10]# make install<br>[root@lh fio-2.1.10]# fio --help

3、如果未成功就用rpm安装:获取fio的rpm安装包后:

[root@localhost tmp]#rpm -ivh fio-2.0.9-1.el6.rf.x86_64.rpm
warning: fio-2.1.10-1.el6.rf.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 6b8d79e6: NOKEY
Preparing... ########################################### [100%]
1:fio ########################################### [100%] //常见故障解决方案:
fio: failed to load engine libaio
[root@localhost tmp] yum install libaio-devel
[root@lh fio-2.1.10]# ./configure
[root@lh fio-2.1.10]# make
[root@lh fio-2.1.10]# make install<br>[root@lh fio-2.1.10]# fio --help

二、FIO工具使用方法:

1、参数说明:

filename=/dev/sdb1 测试文件名称,通常选择需要测试的盘的data目录。
direct=1 测试过程绕过机器自带的buffer。使测试结果更真实。
rw=randwrite 测试随机写的I/O
rw=randrw 测试随机写和读的I/O
bs=16k 单次io的块文件大小为16k
bsrange=512-2048 同上,提定数据块的大小范围
size=5g 本次的测试文件大小为5g,以每次4k的io进行测试。
numjobs=30 本次的测试线程为30.
runtime=1000 测试时间为1000秒,如果不写则一直将5g文件分4k每次写完为止。
ioengine=psync io引擎使用pync方式
rwmixwrite=30 在混合读写的模式下,写占30%
group_reporting 关于显示结果的,汇总每个进程的信息。 此外
lockmem=1g 只使用1g内存进行测试。
zero_buffers 用0初始化系统buffer。
nrfiles=8 每个进程生成文件的数量。
磁盘读写常用测试点:
1. Read=100% Ramdon=100% rw=randread (100%随机读)
2. Read=100% Sequence=100% rw=read (100%顺序读)
3. Write=100% Sequence=100% rw=write (100%顺序写)
4. Write=100% Ramdon=100% rw=randwrite (100%随机写)
5. Read=70% Sequence=100% rw=rw, rwmixread=70, rwmixwrite=30
(70%顺序读,30%顺序写)
6. Read=70% Ramdon=100% rw=randrw, rwmixread=70, rwmixwrite=30
(70%随机读,30%随机写)

2、测试案例:

//1) 顺序写:
描述:向/dev/sda分区存储上以2M块文件大小顺序写1100GB文件
[root@localhost ~]fio -output=/tmp/100S100W -name=100S100W -filename=/dev/sda -ioengine=libaio -direct=1 -blocksize=2M -size=1100GB -rw=write -iodepth=8 -numjobs=1
//2)随机写:
描述:向/dev/sda分区存储上以2M块文件大小随机写1100GB文件
[root@localhost ~]fio -output=/tmp/100R100W -name=100R100W -filename=/dev/sdb:/dev/sdc:/dev/sdd -ioengine=libaio -direct=1 -blocksize=2M -size=3356GB -rw=randwrite -iodepth=8 -numjobs=1
//3)顺序读:
[root@localhost ~]fio -output=/tmp/100S100W -name=100S100W -filename=/dev/sda -ioengine=libaio -direct=1 -blocksize=2M –runtime=1800 -rw=read -iodepth=8 -numjobs=1
//4) 随机读:
[root@localhost ~]fio -output=/tmp/100S100Wsdbsdcsdd -name=100S100W -write_bw_log=bw_log -write_lat_log=lat_log -filename=/dev/sdb:/dev/sdc:/dev/sdd -ioengine=libaio -direct=1 -blocksize=2M -runtime=1800 -rw=randread -iodepth=32 -numjobs=1
//5)混合随机读写:
描述:70%随机读,30%随机写,以2M块文件大小向/dev/sdb:/dev/sdc:/dev/sdd三个分区存储上随机读写300s时间
[root@localhost ~]fio -output=/tmp/100S100W -name=100S100W -filename=/dev/sdb:/dev/sdc:/dev/sdd -ioengine=libaio -direct=1 -blocksize=2M -runtime=300 -rw=randrw -rwmixread=70 -rwmixwrite=30 -iodepth=32 -numjobs=1

3、磁盘IO工具:监控磁盘IO命令:iostat –mx 1 (iostat的安装方法:yum install sysstat)

[root@localhost tmp]# iostat -mx 1
Linux 2.6.32-220.el6.x86_64 (localhost.localdomain) XXXX年XX月XX日 _x86_64_ (32 CPU)
avg-cpu: %user %nice %system %iowait %steal %idle
12.74 0.00 8.95 0.04 0.00 78.27
Device: rrqm/s wrqm/s r/s w/s rMB/s wMB/s avgrq-sz avgqu-sz await svctm %util
sda 0.18 10.05 0.31 7.67 0.01 0.07 18.77 0.00 0.28 0.14 0.11
sdb 0.69 0.10 15.74 11.21 0.17 2.45 190.77 0.34 12.10 0.23 0.63
sdc 0.43 0.06 9.58 5.94 0.13 1.20 176.32 0.03 1.70 0.16 0.25

最新文章

  1. (转)为什么所有浏览器的userAgent都带Mozilla
  2. event
  3. 关于Java 里的String和对象
  4. How to address this problem?
  5. SQLAutoCode - error when attempting to generate schema
  6. MSSQL sp_helptextplus
  7. Visual Studio 2013启用AnkSVN
  8. MySQL 常用命令(持续更新)
  9. Android xml 格式 随笔
  10. 在一个未知的CentOS服务器中如何加上PHP的openssl扩展
  11. 如何在Java Filter 中注入 Service
  12. SqlSever基础 group by之后,加having 对分组之后的数据在进行处理
  13. (1)定义一个接口Compute含有一个方法int computer(int n,int m); (2)设计四个类分别实现此接口,完成+-*/运算 (3)设计一个类UseCompute,含有方法: public void useCom(Compute com, int one, int two) (4)设计一个测试类
  14. Linux内核高端内存 转
  15. sigleSchool 存储过程例1
  16. 【单峰函数,三分搜索算法(Ternary_Search)】UVa 1476 - Error Curves
  17. bzoj1070
  18. django最简单表单入门
  19. bash之管线命令
  20. wows

热门文章

  1. centos7 samba安装教程
  2. antd pro table中的文件上传
  3. MySQL【灵魂拷问】
  4. k8s集群添加新得node节点
  5. net core 微服务 快速开发框架
  6. docker启动服务
  7. go 加锁
  8. linux(centos8):安装prometheus服务端/node_exporter客户端(prometheus 2.18.1)
  9. django—csrf中间件校验流程
  10. Udacity的C++编程练习: Python转C++