磁盘空间性能测试–Linux篇

安装

Linux(Centos/Redhat)yum方式

yum install fio -y

Linux(Centos/Redhat)离线方式

先进行安装2个依赖包

yum install libaio libaio-devel -y

上传文件包(见附件)

tar xf fio-3.2.5.tar.gz

cd fio-3.2.5

./configure

make  #即可在当前目录下生成fio可执行文件。
make install

典型命令

顺序读取测试

fio -filename=/dev/sda -direct=1 -iodepth 1 -thread -rw=read -ioengine=psync -bs=16k -size=200G -numjobs=30 -runtime=1000 -group_reporting -name=mytest

随机读取测试

fio -filename=/dev/sda -direct=1 -iodepth 1 -thread -rw=randread -ioengine=psync -bs=16k -size=200G -numjobs=30 -runtime=1000 -group_reporting -name=mytest

顺序写入测试

fio -filename=/dev/sda -direct=1 -iodepth 1 -thread -rw=write -ioengine=psync -bs=16k -size=200G -numjobs=30 -runtime=1000 -group_reporting -name=mytest

随机写入测试

fio -filename=/dev/sda -direct=1 -iodepth 1 -thread -rw=randwrite -ioengine=psync -bs=16k -size=200G -numjobs=30 -runtime=1000 -group_reporting -name=mytest

混合随机读写测试

fio -filename=/dev/sda -direct=1 -iodepth 1 -thread -rw=randrw -rwmixread=70 -ioengine=psync -bs=16k -size=200G -numjobs=30 -runtime=1000 -group_reporting -name=mytest -ioscheduler=noop

参数说明:

filename=/dev/sdb1 测试文件名称,通常选择需要测试的盘的data目录。
direct=1 测试过程绕过机器自带的buffer。使测试结果更真实。
rw=randwrite/randread 测试随机写/读的I/O
rw=randrw 测试随机写和读的I/O
rw=write/read 测试顺序写/读的I/O
bs=16k 单次io的块文件大小为16k
bsrange=512-2048 同上,提定数据块的大小范围(如非必要可不填写)
size=200G 本次的测试文件大小为200g,以每次4k的io进行测试。
numjobs=30 本次的测试线程为30个
runtime=1000 测试时间为1000秒,如果不写则一直将200g文件分4k每次写完为止。
ioengine=psync io引擎使用pync方式
rwmixwrite=70 在混合读写的模式下,写占70%
group_reporting 关于显示结果的,汇总每个进程的信息
lockmem=1G 只使用1g内存进行测试
zero_buffers 用0初始化系统buffer
nrfiles=8 每个进程生成文件的数量
版权声明:知名"矿工" 发表于 2023-01-19 14:58:46。
转载请注明:磁盘空间性能测试–Linux篇 | 知名"矿工"

暂无评论

暂无评论...