Source From HereQuestionHow can I use
dd command on a Linux to test I/O performance of my hard disk drive? How do I check the
performance of a hard drive including the read and write speed on a Linux operating systems? You can use the following commands on a Linux or Unix-like systems for simple I/O performance test:
* dd command : It is used to monitor the writing performance of a disk device on a Linux and Unix-like system.
* hdparm command : It is used to get/set hard disk parameters including test the reading and caching performance of a disk device on a Linux based system.
In this tutorial you will learn how to use the dd command to test disk I/O performance.
Use dd command to monitor the reading and writing performance of a disk device
1. Open a shell prompt. Or login to a remote server via ssh.
2. Use the
dd command to measure server throughput (
write speed)
dd if=/dev/zero of=/tmp/test1.img bs=1G count=1 oflag=dsync3. Use the
dd command to measure server latency
dd if=/dev/zero of=/tmp/test2.img bs=512 count=1000 oflag=dsync
The
dd command is useful to find out simple sequential I/O performance.
Understanding dd command optionsIn this example, I’m using RAID-10 (
Adaptec 5405Z with SAS SSD) array running on a Ubuntu Linux 14.04 LTS server. The basic syntax is as follows to find out
server throughput:
- # Syntax
- # dd if=/dev/input.file of=/path/to/output.file bs=block-size count=number-of-blocks oflag=dsync
-
- ## GNU dd syntax ##
- ##########################################################
- ##***[Adjust bs and count as per your needs and setup]**##
- ##########################################################
- dd if=/dev/zero of=/tmp/test1.img bs=1G count=1 oflag=dsync
- dd if=/dev/zero of=/tmp/test2.img bs=64M count=1 oflag=dsync
- dd if=/dev/zero of=/tmp/test3.img bs=1M count=256 conv=fdatasync
- dd if=/dev/zero of=/tmp/test4.img bs=8k count=10k
- dd if=/dev/zero of=/tmp/test4.img bs=512 count=1000 oflag=dsync
-
- ## OR alternate syntax for GNU/dd ##
- dd if=/dev/zero of=/tmp/testALT.img bs=1G count=1 conv=fdatasync
Sample outputs:
# dd if=/dev/zero of=/tmp/test1.img bs=1G count=1 oflag=dsync
1+0 records in
1+0 records out
1073741824 bytes (1.1 GB) copied, 2.38434 s, 450 MB/s
Please note that one gigabyte was written for the
test1.img and 450 MB/s was server throughput for this test. Where:
* if=/dev/zero (
if=/dev/input.file) : The name of the input file you want dd the read from.
* of=/tmp/test1.img (
of=/path/to/output.file) : The name of the output file you want
dd write the
input.file to.
* bs=1G (bs=block-size) : Set the size of the block you want
dd to use. 1 gigabyte was written for the test. Please note that Linux will need 1GB of free space in RAM. If your test system does not have sufficient RAM available, use a smaller parameter for
bs (
such as 128MB or 64MB and so on).
* count=1 (count=number-of-blocks): The number of blocks you want dd to read.
* oflag=dsync (oflag=dsync) : Use synchronized I/O for data. Do not skip this option.
This option get rid of caching and gives you good and accurate results
* conv=fdatasyn: Again, this tells dd to require a complete “sync” once, right before it exits. This option is equivalent to oflag=dsync.
Finding server latency timeIn this example, 512 bytes were written one thousand times to get RAID10 server latency time:
# dd if=/dev/zero of=/tmp/test2.img bs=512 count=1000 oflag=dsync
Sample outputs:
1000+0 records in
1000+0 records out
512000 bytes (512 kB) copied, 0.60362 s, 848 kB/s
Please note that server throughput and latency time depends upon server/application load too. So I
recommend that you run these tests on a newly rebooted server as well as peak time to get better idea about your workload. You can now compare these numbers with all your devices.
But why the server throughput and latency time are so low?Low values does not mean you are using slow hardware. The value can be low because of the HARDWARE RAID10 controller’s cache.
Use hdparm command to see buffered and cached disk read speedI suggest you run the following commands 2 or 3 times Perform timings of device reads for benchmark and comparison purposes:
- ### Buffered disk read test for /dev/sda ##
- hdparm -t /dev/sda1
- ## OR ##
- hdparm -t /dev/sda
To perform timings of cache reads for benchmark and comparison purposes again run the following command 2-3 times (
note the -T option):
- ## Cache read benchmark for /dev/sda ###
- hdparm -T /dev/sda1
- ## OR ##
- hdparm -T /dev/sda
OR combine both tests:
Sample outputs:

Again note that due to filesystems caching on file operations, you will always see high read rates.
Use dd command on Linux to test read speedTo get accurate read test data, first discard caches before testing by running the following commands:
- flush
- echo 3 | sudo tee /proc/sys/vm/drop_caches
- time dd if=/path/to/bigfile of=/dev/null bs=8k
One execution result:
# time dd if=/tmp/test1.img of=/dev/null bs=8k
131072+0 records in
131072+0 records out
1073741824 bytes (1.1 GB) copied, 0.315225 s, 3.4 GB/s
real 0m0.319s
user 0m0.050s
sys 0m0.269s
Linux Laptop exampleRun the following command:
- ### Debian Laptop Throughput With Cache ##
- dd if=/dev/zero of=/tmp/laptop.bin bs=1G count=1 oflag=direct
-
- ### Deactivate the cache ###
- hdparm -W0 /dev/sda
-
- ### Debian Laptop Throughput Without Cache ##
- dd if=/dev/zero of=/tmp/laptop.bin bs=1G count=1 oflag=direct