A Comparison of Software RAID Types
Linux Software RAID Performance Comparisons
The Problem
We expect RAID-0 to be faster than RAID-5 and that RAID-6 will be
slower than RAID-5, but by how much? Here, we compare 5 spindles in
each configuration, as well as the same number of data spindles in
each configuration.
The Controller
- Supermicro AOC-SAT2-MV8
- 8 SATA II ports
- 64-bit PCI-X133MHz (tested in 32-bit PCI slot)
- Chipset: MV88SX6081
- Linux driver: sata_mv
- Cost: $99.99 from newegg.com
- Configuration: JBOD
The Test System
- Motherboard: Asus K8N-DRE
- Processors: Two 1.8GHz Opteron 244
- RAM: 8GB DDR400 running at 333MHz
- Slots: 1 32-bit PCI; 1 PCI Express x16
- Drives: Seagate Barracuda 7200.11 1000Gbytes ST31000333AS
- Drive cage: Supermicro CSE-M35T-1B 5-Bay Enclosure (fits in
three 5-inch chassis bays; sells for about $100-$120 from
newegg.com)
The Test Matrix
- Read Percentage: 100% (pure read), 50% (mixed), 0% (pure write)
- Random Percentage: 0% (sequential), 100% (random)
- Thread counts: 1 and 20
- Block sizes: 4k, 8k, 32k, 64k, 256k, 1m, 4m, 8m, 64m
- Targets: All 5 driver were tested simultaneously, as well as
each drive individually.
- All I/Os are issued using the O_DIRECT flag.
- All tests last 20 seconds.
Conclusion
RAID-0 lacks parity protection and is only significantly faster than
RAID-5 and RAID-6 for write-based workloads. While it is typical to
use RAID-0 for read-only workloads, there is no compelling
performance reasons to do so -- on read-only workloads, RAID-5 and
RAID-6 perform nearly as well (or better).
RAID-6 must compute twice the parity information as RAID-5, so one
typically expects it to perform significantly worse than RAID-5.
This is not the case. Indeed, RAID-6 performance is nearly
identical to RAID-5 performance for I/O sizes under 256KB. Capacity
and reliability issues -- not performance issues -- should guide the
selection between RAID-5 and RAID-6. (This likely assumes
sufficient CPU, but the test system is I/O bound, not CPU bound.)
My recommendation is to never use RAID-0, and to select between
RAID-5 and RAID-6 based on available capacity, data-recovery, and
reliability needs.
Sequential Single Threaded Tests
For sequential reads, all RAID types have comparable performance up
through 64KB I/O sizes. After that, RAID-0 saturates the controller
and RAID-5 and -6 remain comparable. For workloads including
writes, RAID-0 clearly has higher performance (because no parity
computation is required); but RAID-5 and -6 are, again, comparable.
data:image/s3,"s3://crabby-images/73b76/73b76789b6839e7dd71af4f17a2b65d7262361c4" alt=""
data:image/s3,"s3://crabby-images/348c9/348c9ab1c3a0ec291d9ba027d80863e945434b23" alt=""
data:image/s3,"s3://crabby-images/533e1/533e167978557f259705079599e643a38bbd6fe4" alt=""
data:image/s3,"s3://crabby-images/40689/40689e2e36bc1583137eaf60e727aaf75438493e" alt=""
data:image/s3,"s3://crabby-images/673be/673be19af1a1fb28fc016d63822287bc249fbf59" alt=""
data:image/s3,"s3://crabby-images/06ee6/06ee6be565255e42220746c5f68c4adf91dbf634" alt=""
data:image/s3,"s3://crabby-images/85f63/85f63b974a59e95070e0736f74e4ef8a92ba5f1e" alt=""
data:image/s3,"s3://crabby-images/619fd/619fd9228b2281467a895380551812e55eae23a9" alt=""
data:image/s3,"s3://crabby-images/6709e/6709e0c0a45e5d4e1be75663b65882b3535cb141" alt=""
Random Single Threaded Tests
For random reads, all RAID types are comparabe, with RAID-0 having
slightly higher performance. Writes show RAID-0's performance
superiority, but RAID-5 and -6 are very similar up through 256KB
I/O sizes, after which RAID-5 is superior.
data:image/s3,"s3://crabby-images/5679c/5679cb18182396ffee9d44142e764f8f2055b978" alt=""
data:image/s3,"s3://crabby-images/229e7/229e7be9e20e25feb4e71c3cca6b6b80e434933a" alt=""
data:image/s3,"s3://crabby-images/5c64d/5c64dc0c905a046da9c5a09497718693d6c23e76" alt=""
data:image/s3,"s3://crabby-images/ef846/ef846760d7e3a5f831bcd1f0ef3507caa54759c2" alt=""
data:image/s3,"s3://crabby-images/47dae/47dae63a3af2cfefbc05a2a0c9e5002ea31abb57" alt=""
data:image/s3,"s3://crabby-images/912ea/912eabda49f2fe9816c95c6d5ec9dec85dce9183" alt=""
data:image/s3,"s3://crabby-images/e7134/e7134669089f33ed1e74b8119df5d43e6d5f0b7b" alt=""
data:image/s3,"s3://crabby-images/95add/95add8842034f6de3848d0c92853b8e7ef9ef1c5" alt=""
data:image/s3,"s3://crabby-images/5a43d/5a43dd1677376d4a67f57f98d9ace9324b1e9fcc" alt=""
Sequential Multi-Threaded Tests
All RAID types have comparable performance for mutli-threaded
sequential reads up through 64KB I/O sizes, with RAID-5 and -6
actually outperforming RAID-0 for small I/O sizes. RAID-0 is
superior for larger I/O sizes, and, as expected, for writes.
data:image/s3,"s3://crabby-images/9f9bf/9f9bfc8cea9799cbeadf32597661270f098e9c2b" alt=""
data:image/s3,"s3://crabby-images/783a3/783a367ff165be9fd747016ec037bb8012966454" alt=""
data:image/s3,"s3://crabby-images/fd6a7/fd6a7d81b40cac8aa56d02a42437b99cab7c1593" alt=""
data:image/s3,"s3://crabby-images/feeee/feeee7f7836e85d5250c53ce62e5a3bfdb827ca0" alt=""
data:image/s3,"s3://crabby-images/ed5d1/ed5d1af255274f08253db9811c50b1fdf5a9c3b8" alt=""
data:image/s3,"s3://crabby-images/36ebe/36ebe9508945c2917decc0c734d76a228831cdf8" alt=""
data:image/s3,"s3://crabby-images/6d90a/6d90a9d8a6c70e975520879ba130962bc71fcd70" alt=""
data:image/s3,"s3://crabby-images/cdbbe/cdbbe69de475c9bd7bc023eb8971d5e0c0df4d6f" alt=""
data:image/s3,"s3://crabby-images/97e4c/97e4cf79917eb04ca06417fe18d2b7ba4cdb50ff" alt=""
Random Multi-Threaded Tests
Multi-threaded random reads perform similarly across RAID types,
nearly identially through 64KB I/O sizes. Again, RAID-0 has higher
performance for workloads including writes, but RAID-5 and -6 are,
again, nearly identical through 256KB I/O sizes.
data:image/s3,"s3://crabby-images/cb195/cb195bac8893f50bdcc093a64f7d993b10af26ab" alt=""
data:image/s3,"s3://crabby-images/dbc8a/dbc8a9d7913633d78226f395f03c84b5a9bd577d" alt=""
data:image/s3,"s3://crabby-images/f674c/f674c6a3f65ea3d3f9f9cbade3694e4e86bc55f0" alt=""
data:image/s3,"s3://crabby-images/0f0cf/0f0cf762eac75125dd9207058c5b6659bc1f3d75" alt=""
data:image/s3,"s3://crabby-images/af431/af431f4047e1e0e814fe2a681fe44451fcae8862" alt=""
data:image/s3,"s3://crabby-images/099dd/099dd9c88014953b25d629a7bb4f65d0659d7cfa" alt=""
data:image/s3,"s3://crabby-images/8c83b/8c83b673a82204ba6593ceea0975746bf55bed3d" alt=""
data:image/s3,"s3://crabby-images/67113/6711315f201636a2b0bcdebc94156f8bd556b084" alt=""
data:image/s3,"s3://crabby-images/f7d90/f7d900b5eb98e1d0df3daf82fd37ef1f2aab3cc1" alt=""