Windows Azure中建立虚拟机后,通常有磁盘性能测试的需求。下文针对基Windows Azure Centos 虚拟机环境进行磁盘性能测试。

   在Windows Azure中建立 Linux 虚拟机后,可以看见两个磁盘分别为sda和sdb,其中sda为系统盘,sdb为临时盘。临时盘为虚拟机所在物理服务器的本地存储,在Windows Azure执行计划内或计划外维护时,虚拟机会移动到其他宿主服务器,所以会造成临时盘的内容丢失。除系统盘和临时盘外,Windows Azure还允许用户挂载数据盘。对于Linux虚拟机,系统盘才30G的空间,所以在实际应用场景中需要挂载数据盘存储应用数据。在Windows Azure虚拟机中,对于A7类型的虚拟机最多允许挂载16个数据磁盘,提供16TB的存储空间并且这些磁盘支持通过Raid机制获得更好的读/写性能。

1.    安装磁盘测试工具  

Fio是常见的磁盘IOPS测试工具。首先在Centos中安装Fio:

yum install gcc libaio-devel –y

wKiom1Neb4SRCUCwAABANXoEKQU029.jpg

下载Fio 并安装:

wget http://brick.kernel.dk/snaps/fio-2.1.6.1.tar.gz

tar -zxvf fio-2.1.6.1.tar.gz

cd fio-2.1.6.1

make&& make install

2.    查看当前磁盘信息

fdisk -l

wKiom1NecCyxqH6UAAFGAcadP3I790.jpg

可以看见当前系统盘和临时盘

3.    附件数据磁盘

在Windows Azure的管理portal中,为测试虚拟机新增数据磁盘。

wKiom1NedJXwlH2qAAIOstnx-kc050.jpg

输入磁盘大小,附加成功后查看磁盘信息:

Sudo grep scsi /var/log/messages

wKioL1NedN_DVrc3AAEGvhCxvBA836.jpg

对新磁盘执行分区操作:

sudo fdisk /dev/sdc

分区完成后创建文件系统:

sudo mkfs -t ext4 /dev/sdc1

wKiom1NedffwaTX_AAHYLcHiOOA139.jpg

创建挂载点

sudo mkdir /datadrive

sudo mount /dev/sdc1 /datadrive

为下次重启能自动挂载,需要修改/etc/fstab文件

执行sudo -i blkio 获取新磁盘的uuid,并添加到fstab文件

`UUID=33333333-3b3b-3c3c-3d3d-3e3e3e3e3e3e   /datadrive   ext4   defaults   1   2`

4.    执行测试

对系统盘执行随机写测试

fio -filename=/dev/sda1 -direct=1 -iodepth 1 -thread -rw=randwrite -ioengine=psync-bs=16k -size=20G -numjobs=30 -runtime=1000 -group_reporting -name=test
wKioL1Ned23A1Q5eAADDYaN5Ce8873.jpg

测试结果的iops为478,与windows Azure每磁盘500IOPS较为一致。

接下来执行随机读和随机读写测试:

随机读测试


fio -filename=/dev/sda1 -direct=1 -iodepth1 -thread -rw=randread -ioengine=psync -bs=16k -size=2G -numjobs=10-runtime=1000 -group_reporting-name=test

wKiom1NeeTOiqTMCAADSVtk1RKM473.jpg

随机读写测试

fio -filename=/dev/sda1 -direct=1 -iodepth 1 -thread -rw=randrw-rwmixread=70 -ioengine=psync -bs=16k -size=20G -numjobs=30 -runtime=100-group_reporting -name=test1

用以上方法对数据盘/dev/sdc1进行测试。

参数说明:

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,以每次4kio进行测试。

numjobs=30本次的测试线程为30.

runtime=1000测试时间为1000秒,如果不写则一直将5g文件分4k每次写完为止。

ioengine=psyncio引擎使用pync方式

rwmixwrite=30在混合读写的模式下,写占30%

group_reporting关于显示结果的,汇总每个进程的信息。

此外

lockmem=1g只使用1g内存进行测试。

zero_buffers0初始化系统buffer

nrfiles=8每个进程生成文件的数量