data:image/s3,"s3://crabby-images/bdb4b/bdb4bc9e931d68a796b56d31e75ff70aac1ec9d6" alt=""
Tips and tricks for using diskspd especially useful for those familar with tools like fio
Tip #1 The default OIO is “2” if no other parameters are specified
- This is documented on the diskpsd page but most workload generators that i use will default to a single OIO, so it’s worth pointing out.
- Note that in the command below there is no “-t” switch.
data:image/s3,"s3://crabby-images/c0726/c072632c8223a73fef54b1649488334a9d2b148b" alt=""
data:image/s3,"s3://crabby-images/1bc72/1bc7285c90a72be04010aec0ba6aee33c6634cfc" alt=""
Tip #2 The -o parameter is per-disk and per thread.
- Run diskspd with –o32 (single thread) generates a total of 32 OIO
data:image/s3,"s3://crabby-images/61954/619545fcf3fd1c9c4bfff828acd345eb23776cd5" alt=""
data:image/s3,"s3://crabby-images/89dee/89dee99d0078036fe251c52e523f0b442b1ecb3d" alt=""
- Run diskspd with –o32 and -t2 (two threads) generates a total of 64 OIO
data:image/s3,"s3://crabby-images/d1073/d1073de38547ef68ff3804af6a9cb90865207406" alt=""
data:image/s3,"s3://crabby-images/4ea88/4ea88ac9bcd3624e9a0b954fc52670a6ef154012" alt=""
- Run diskspd with –o32, -t8 (eight threads) generates a total of 256 OIO
data:image/s3,"s3://crabby-images/88b64/88b64369a42cb22e9b7d119aa352476f7b45ad46" alt=""
data:image/s3,"s3://crabby-images/19318/19318629a8c8e8eb3972e27ed164b7bc20b016cb" alt=""
Tip #3 Threads and OIO are per disk device.
Using the above (-o32 -t8) with 4 disks will yield 1024 OIO (32*8*4) more than most physical HBA’s can deliver by default
data:image/s3,"s3://crabby-images/578d2/578d2f786c7ba20ccfc6bafa7fbe845bf2d27fcf" alt=""
data:image/s3,"s3://crabby-images/1d6cf/1d6cf926cd85a36f05e9877e104cb34faf9927b9" alt=""
Tip #4 To keep total OIO constant across disk count use -O and -F
In the case where we want to keep the total OIO constant at 128 but experiment with different numbers of disks use for example -O32 -F8 rather than -O32 -t8.
- 4 Devices
data:image/s3,"s3://crabby-images/6132a/6132a0d3880e628b7e1bf72e008b8bcdcfad2a81" alt=""
data:image/s3,"s3://crabby-images/2ebd9/2ebd9539bb7f1e4bccefed054542057133a12f63" alt=""
- 2 Devices
data:image/s3,"s3://crabby-images/954fa/954fadf85337cc8097ea48c7ccb9423fe6361f3b" alt=""
data:image/s3,"s3://crabby-images/a00c9/a00c9d23cbd5fdc73ef110156622968a098476e5" alt=""
- 1 Device
data:image/s3,"s3://crabby-images/db63b/db63b1e64e9129f9dfc8575e5322f93369b3b572" alt=""
data:image/s3,"s3://crabby-images/7573c/7573c71e452ee4ea3b827228689e3e95fd1f6f3f" alt=""
Tip #5 Creating a file with -Zr does not fill the file.
To create a file with non-null bytes, you will have to do a separate write phase after initial creation.
Tip #6 The default fill pattern is highly compressible
- Writing out a file without a switch writes a Repeating pattern every 256 bytes. A 1FFF file will compress by KKK% to JJJbytes
- Writing out a file with “-Z” writes NULL bytes
- Writing out a file with “-Zr” writes totally random bytes.
Tip #7 “Raw” devices are supported
diskspd supports writing directly to the drive (e.g. without a filesystem) using the format #<disknum>
data:image/s3,"s3://crabby-images/d195d/d195d5cdfe474453086c63fef9fcadb5c1303d62" alt=""
Tip #8 Writing to a file/device without a time period will default to 10 seconds
Anyone coming from e.g. fio might expect the write to fill the entire file.
data:image/s3,"s3://crabby-images/306d5/306d5b43f26629a752c99935fdeb70f09b9a00f1" alt=""
data:image/s3,"s3://crabby-images/791be/791be6aad8482689ed573a768fd1c46cc4fe2421" alt=""