SQLIO


功能:磁盘IO压力测试工具,SQLIO主要是模拟随机或者顺序的方式来测试磁盘IO的性能。

SQLIO Disk Subsystem Benchmark Tool工具下载地址:

http://www.microsoft.com/en-us/download/details.aspx?id=20163

RAID存储技术在SQL Server服务器上已经被广泛使用,对于存储介质,有很多层面的硬件和固件,以及存储管理软件配置。如果设置不恰当,同样的硬件最后的效能会差别很大。

 

微软提供了一个工具叫SQLIO.exe,专门用作数据库硬盘压力测试。工具安装好后,主要用到的是两个文件。

1. Param.txt。

-----------------------------内容范例----------------------------

#c:\testfile.dat 2 0x00 100
d:\testfile.dat 4 0x00 1024

-----------------------------------------------------------------------

每行的格式及其参数的含义如下。

l <Path to test file>: 测试用的文件和它的完整路径。

l <Number of threads (per test file)>: 测试同时使用多少个线程进行。建议和CPU数目一致。

l <Mask>: 始终使用0x0。

l <Size of test file in MB>: 测试文件的大小,最好是SAN(或RAID Controller)的读写缓存大小的2到4倍,A5机器一般是512MB,这里可以用1024MB。

如果某行要注释掉,就在最前面加一个#号。

所以上面范例的意思是,在D盘的根目录下,用4个线程,一个1024MB的文件来做压力测试。

 

2. SQLIO.exe。

也就是主测试文件。它有很多参数,具体含义如下表:

选项

说明

-o

测试文件会在磁盘上产生的队列长度(Disk Queue Length)。一般来说,这个值越高,单位时间磁盘的吞吐量就越大。但是有些磁盘会在Queue Length太大的情况下出问题。常用的有8、32和64

-LS

记录磁盘反应时间,这是一个推荐使用的选项

-k

指定是读还是写(R或W)

-s

测试持续多少秒。一般至少5到10分钟。

-b

每次I/O请求的大小。

-f

I/O的种类,是随机(’random’)还是连续(’sequential’)的。

-F

参数文件的名字,默认就是param.txt


由于测试需要覆盖不同的I/O类型,所以可以用下面这样的批处理文件来做一套测试

见附件testIO.bat


这里输入timeout命令的完整路径,是因为若装有cygwin,会因为环境变量Path的优先级而导致找到的timeout命令不是Windows下的该命令,而导致命令失败。

运行的时候在命令行下运行:

testIO.bat > out.txt

结果会输出在相同目录下的out.txt文件里。每一行命令都会有它的输出。


在做随机读和随机写的时候,Disk Transfers/sec的数量不会因为每个Transfer(每次I/O)的大小不同而有明显的变化,Avg. Disk sec/Transfer也差不多。所以每完成一次I/O,花的时间都差不多,Transfer越大,那么Disk Bytes/sec也就越高。但是整体性能,还是比不上做连续读、写的时候。


在做连续读和写的时候,由于数据是连续的,所以不管每次做的I/O多大,最终的Disk Bytes/sec值相差不大。


当做的事情不一样的时候,磁盘的吞吐量会有很大的差异。在和硬盘供应商讨论磁盘性能的时候,也要要求他们提供磁盘在不同I/O行为下的能力值,而不是某个最佳值。


对于out.txt的输出结果,IOs/sec相当于磁盘的IOPs,MB/s相当于磁盘数据的吞吐量。Latency相当于磁盘的反应时间。

见附件out.txt

 

针对SQLIO的输出结果有一个非常好用的分析工具(SQLIO Analyzer),将SQLIO的结果保存到txt文件,用shell命令筛选出相关数据,如:  
grep “IOs/sec” out.txt | awk ‘{print $2}’    
然后导入分析工具,可以出现下面的图表结果。

见附件sqlio_analyzer_results.xls