Input/output operations per second (IOPS, pronounced eye-ops) is an input/output performance measurement used to characterize computer storage devices like hard disk drives (HDD), solid state drives (SSD), and storage area networks (SAN). Like benchmarks, IOPS numbers published by storage device manufacturers do not directly relate to real-world application performance.[1][2]

Background

edit

To meaningfully describe the performance characteristics of any storage device, it is necessary to specify a minimum of three metrics simultaneously: IOPS, response time, and (application) workload. Absent simultaneous specifications of response-time and workload, IOPS are essentially meaningless. In isolation, IOPS can be considered analogous to "revolutions per minute" of an automobile engine i.e. an engine capable of spinning at 10,000 RPMs with its transmission in neutral does not convey anything of value, however an engine capable of developing specified torque and horsepower at a given number of RPMs fully describes the capabilities of the engine.

The specific number of IOPS possible in any system configuration will vary greatly, depending upon the variables the tester enters into the program, including the balance of read and write operations, the mix of sequential and random access patterns, the number of worker threads and queue depth, as well as the data block sizes.[1] There are other factors which can also affect the IOPS results including the system setup, storage drivers, OS background operations etc. Also, when testing SSDs in particular, there are preconditioning considerations that must be taken into account.[3]

Performance characteristics

edit
 
Random access compared to sequential access.

The most common performance characteristics measured are sequential and random operations. Sequential operations access locations on the storage device in a contiguous manner and are generally associated with large data transfer sizes, e.g. ≥ 128 kB. Random operations access locations on the storage device in a non-contiguous manner and are generally associated with small data transfer sizes, e.g. 4 kB.

The most common performance characteristics are as follows:

Measurement Description
Total IOPS Total number of I/O operations per second (when performing a mix of read and write tests)
Random Read IOPS Average number of random read I/O operations per second
Random Write IOPS Average number of random write I/O operations per second
Sequential Read IOPS Average number of sequential read I/O operations per second
Sequential Write IOPS Average number of sequential write I/O operations per second

For HDDs and similar electromechanical storage devices, the random IOPS numbers are primarily dependent upon the storage device's random seek time, whereas, for SSDs and similar solid state storage devices, the random IOPS numbers are primarily dependent upon the storage device's internal controller and memory interface speeds. On both types of storage devices, the sequential IOPS numbers (especially when using a large block size) typically indicate the maximum sustained bandwidth that the storage device can handle.[1] Often sequential IOPS are reported as a simple Megabytes per second number as follows:

  (then converted to MB/s)

Some HDDs/SSDs will improve in performance as the number of outstanding IOs (i.e. queue depth) increases. This is usually the result of more advanced controller logic on the drive performing command queuing and reordering commonly called either Tagged Command Queuing (TCQ) or Native Command Queuing (NCQ). Many consumer SATA HDDs either cannot do this, or their implementation is so poor that no performance benefit can be seen.[citation needed] Enterprise class SATA HDDs, such as the Western Digital Raptor and Seagate Barracuda NL will improve by nearly 100% with deep queues.[4] High-end SCSI drives more commonly found in servers, generally show much greater improvement, with the Seagate Savvio exceeding 400 IOPS—more than doubling its performance.[citation needed]

While traditional HDDs have about the same IOPS for read and write operations, many NAND flash-based SSDs and USB sticks are much slower writing than reading due to the inability to rewrite directly into a previously written location forcing a procedure called garbage collection.[5][6][7] This has caused hardware test sites to start to provide independently measured results when testing IOPS performance.

Flash SSDs, such as the Intel X25-E (released 2010), have much higher IOPS than traditional HDD. In a test done by Xssist, using Iometer, 4 KB random transfers, 70/30 read/write ratio, queue depth 4, the IOPS delivered by the Intel X25-E 64 GB G1 started around 10000 IOPs, and dropped sharply after 8 minutes to 4000 IOPS, and continued to decrease gradually for the next 42 minutes. IOPS vary between 3000 and 4000 from approximately 50 minutes and onwards, for the rest of the 8+ hours the test ran.[8] Even with the drop in random IOPS after the 50th minute, the X25-E still has much higher IOPS compared to traditional hard disk drives. Some SSDs, including the OCZ RevoDrive 3 x2 PCIe using the SandForce controller, have shown much higher sustained write performance that more closely matches the read speed.[9] For example, a typical operating system has many small files (such as DLLs ≤ 128 kB), so SSD is more suitable for system drive.[10]

Examples

edit

Mechanical hard drives

edit

Block size used when testing significantly affects the number of IOPS performed by a given drive. See below for some typical performance figures:[11]

Drive (Type / RPM) IOPS

(4 KB block, random)

IOPS

(64 KB block, random)

MB/s (64KB block, random) IOPS

(512 KB block, random)

MB/s (512 KB block, random) MB/s (large block, sequential)
SAS / 15K 188 - 203 175 - 192 11.2 – 12.3 115 – 135 58.9 – 68.9 91.5 – 126.3
FC / 15K 163 - 178 151 - 169 9.7 – 10.8 97 – 123 49.7 – 63.1 73.5 – 127.5
FC / 10K 142 - 151 130 – 143 8.3 – 9.2 80 – 104 40.9 – 53.1 58.1 – 107.2
SAS / 10K 142 - 151 130 – 143 8.3 – 9.2 80 – 104 40.9 – 53.1 58.1 – 107.2
SATA / 7200 73 - 79 69 - 76 4.4 – 4.9 47 – 63 24.3 – 32.1 43.4 – 97.8
SATA / 5400 57 55 3.5 44 22.6

Solid-state devices

edit
Device Type IOPS Interface Notes
Intel X25-M G2 (MLC) SSD ~8,600 IOPS[12] SATA 3 Gbit/s Intel's data sheet[13] claims 6,600/8,600 IOPS (80 GB/160 GB version) and 35,000 IOPS for random 4 KB writes and reads, respectively.
Intel X25-E (SLC) SSD ~5,000 IOPS[14] SATA 3 Gbit/s Intel's data sheet[15] claims 3,300 IOPS and 35,000 IOPS for writes and reads, respectively. 5,000 IOPS are measured for a mix. Intel X25-E G1 has around 3 times higher IOPS compared to the Intel X25-M G2.[16]
G.Skill Phoenix Pro SSD ~20,000 IOPS[17] SATA 3 Gbit/s SandForce-1200 based SSD drives with enhanced firmware, states up to 50,000 IOPS, but benchmarking shows for this particular drive ~25,000 IOPS for random read and ~15,000 IOPS for random write.[17]
Samsung SSD 850 PRO SSD Up to[neutrality is disputed] 100,000 read IOPS
Up to[neutrality is disputed] 90,000 write IOPS[18][non-primary source needed]
SATA 6 Gbit/s 4 KB aligned random I/O at QD32
10,000 read IOPS, 36,000 write IOPS at QD1
550 MB/s sequential read, 520 MB/s sequential write on 256 GB and larger models
550 MB/s sequential read, 470 MB/s sequential write on 128 GB model[18]
Virident Systems tachIOn SSD Up to[neutrality is disputed] 320,000 sustained READ IOPS using 4 kB blocks, and up to 200,000 sustained WRITE IOPS using 4kB blocks[19] PCIe
OCZ RevoDrive 3 X2 SSD Up to[neutrality is disputed] 200,000 Random Write 4k IOPS[20] PCIe
DDRdrive X1 SSD Up to[neutrality is disputed] 300,000+ (512B Random Read IOPS) and 200,000+ (512B Random Write IOPS)[21][22][23][non-primary source needed][24] PCIe
Samsung SSD 960 EVO SSD Up to[neutrality is disputed] 380,000 read IOPS
Up to[neutrality is disputed] 360,000 write IOPS[25][non-primary source needed]
NVMe over PCIe 3.0 x4, M.2 4 kB aligned random I/O with four workers at QD4 (effectively QD16),[26] 1 TB model
14,000 read IOPS, 50,000 write IOPS at QD1
330,000 read IOPS, 330,000 write IOPS on 500 GB model
300,000 read IOPS, 330,000 write IOPS on 250 GB model
Up to[neutrality is disputed] 3.2 GB/s sequential read, 1.9 GB/s sequential write[25]
Samsung SSD 960 PRO SSD Up to[neutrality is disputed] 440,000 read IOPS
Up to[neutrality is disputed] 360,000 write IOPS[25][non-primary source needed]
NVMe over PCIe 3.0 x4, M.2 4kB aligned random I/O with four workers at QD4 (effectively QD16),[26] 1 TB and 2 TB models
14,000 read IOPS, 50,000 write IOPS at QD1
330,000 read IOPS, 330,000 write IOPS on 512 GB model
Up to[neutrality is disputed] 3.5 GB/s sequential read, 2.1 GB/s sequential write[25]
Kaminario K2 SSD Up to[neutrality is disputed] 2,000,000 IOPS.[27]
1,200,000 IOPS in SPC-1 benchmark simulating business applications[28][29]
FC MLC Flash
NetApp FAS6240 cluster Flash/Disk 1,261,145 SPECsfs2008 nfsv3 IOPs using 1,440 15k disks, across 60 shelves, with virtual storage tiering.[30][unreliable source?] NFS, SMB, FC, FCoE, iSCSI SPECsfs2008 is the latest version of the Standard Performance Evaluation Corporation benchmark suite measuring file server throughput and response time, providing a standardized method for comparing performance across different vendor platforms.
EMC DSSD D5 Flash Up to[neutrality is disputed] 10 million IOPS[31][non-primary source needed] PCIe Out of Box, up to 48 clients with high availability. PCIe Rack Scale Flash Appliance. Product discontinued.[32]

See also

edit

References

edit
  1. ^ a b c Lowe, Scott (2010-02-12). "Calculate IOPS in a storage array". techrepublic.com. Retrieved 2011-07-03.
  2. ^ "Getting The Hang Of IOPS v1.3". 2012-08-03. Retrieved 2013-08-15.
  3. ^ Smith, Kent (2009-08-11). "Benchmarking SSDs: The Devil is in the Preconditioning Details" (PDF). SandForce.com. Retrieved 2015-05-05.
  4. ^ "SATA in the Enterprise - A 500 GB Drive Roundup | StorageReview.com - Storage Reviews". StorageReview.com. 2006-07-13. Archived from the original on 2013-05-05. Retrieved 2013-05-13.
  5. ^ Xiao-yu Hu; Eleftheriou, Evangelos; Haas, Robert; Iliadis, Ilias; Pletka, Roman (2009). "Write Amplification Analysis in Flash-Based Solid State Drives". IBM. CiteSeerX 10.1.1.154.8668. {{cite journal}}: Cite journal requires |journal= (help)
  6. ^ "SSDs - Write Amplification, TRIM and GC" (PDF). OCZ Technology. Archived from the original (PDF) on 2012-05-26. Retrieved 2010-05-31.
  7. ^ "Intel Solid State Drives". Intel. Retrieved 2010-05-31.
  8. ^ "Intel X25-E 64GB G1, 4KB Random IOPS, iometer benchmark". 2010-03-27. Retrieved 2010-04-01.
  9. ^ "OCZ RevoDrive 3 x2 PCIe SSD Review – 1.5GB Read/1.25GB Write/200,000 IOPS As Little As $699". 2011-06-28. Retrieved 2011-06-30.
  10. ^ "SSD vs. HDD: Which Do You Need?". SSD vs. HDD: Which Do You Need?. Retrieved 2024-06-24.
  11. ^ "RAID Performance Calculator - WintelGuy.com". wintelguy.com. Retrieved 2019-04-01.
  12. ^ Schmid, Patrick; Roos, Achim (2008-09-08). "Intel's X25-M Solid State Drive Reviewed". Retrieved 2011-08-02.
  13. ^ "Intel X18-M/X25-M SATA Solid State Drive — 34 nm Product Line" (PDF). Intel. January 2010. Archived from the original (PDF) on 2010-08-12. Retrieved 2010-07-20.
  14. ^ Schmid, Patrick; Roos, Achim (27 February 2009). "Intel's X25-E SSD Walks All Over The Competition: They Did It Again: X25-E For Servers Takes Off". TomsHardware.com. Retrieved 2013-05-13.
  15. ^ "Archived copy" (PDF). Archived from the original (PDF) on 2009-02-06. Retrieved 2009-03-18.{{cite web}}: CS1 maint: archived copy as title (link)
  16. ^ "Intel X25-E G1 vs Intel X25-M G2 Random 4 KB IOPS, iometer". May 2010. Retrieved 2010-05-19.
  17. ^ a b "G.Skill Phoenix Pro 120 GB Test - SandForce SF-1200 SSD mit 50K IOPS - HD Tune Access Time IOPS (Diagramme) (5/12)". Tweakpc.de. Retrieved 2013-05-13.
  18. ^ a b "Samsung SSD 850 PRO Specifications". Samsung Electronics. Retrieved 7 June 2017.
  19. ^ "Virident's tachIOn SSD flashes by". theregister.co.uk.
  20. ^ "OCZ RevoDrive 3 X2 480GB Review | StorageReview.com - Storage Reviews". StorageReview.com. 2011-06-28. Retrieved 2013-05-13.
  21. ^ http://www.ddrdrive.com/ddrdrive_press.pdf [bare URL PDF]
  22. ^ "Archived copy" (PDF). Archived from the original (PDF) on 2009-05-20. Retrieved 2009-05-22.{{cite web}}: CS1 maint: archived copy as title (link)
  23. ^ "Archived copy" (PDF). Archived from the original (PDF) on 2009-05-20. Retrieved 2009-05-22.{{cite web}}: CS1 maint: archived copy as title (link)
  24. ^ Allyn Malventano (2009-05-04). "DDRdrive hits the ground running - PCI-E RAM-based SSD | PC Perspective". Pcper.com. Archived from the original on 2013-07-14. Retrieved 2013-05-13.
  25. ^ a b c d Samsung Electronics. "NVMe SSD 960 PRO/EVO". Retrieved 7 June 2017.
  26. ^ a b Ramseyer, Chris (18 October 2016). "Samsung 960 Pro SSD Review". Tom's Hardware. Retrieved 9 June 2017. Samsung tests NVMe products with four workers at QD4
  27. ^ Lyle Smith. "Kaminario Boasts Over 2 Million IOPS and 20 GB/s Throughput on a Single All-Flash K2 Storage System". Archived from the original on 2016-04-22. Retrieved 2015-12-19.
  28. ^ Mellor, Chris (2012-07-30). "Chris Mellor, The Register, July 30, 2012: "Million-plus IOPS: Kaminario smashes IBM in DRAM decimation"". Theregister.co.uk. Retrieved 2013-11-14.
  29. ^ Storage Performance Council. "Storage Performance Council: Active SPC-1 Results". storageperformance.org. Archived from the original on 2014-09-25. Retrieved 2012-09-25.
  30. ^ "SpecSFS2008". Retrieved 2014-02-07.
  31. ^ "Rack-Scale Flash Appliance - DSSD D5 EMC". EMC. Retrieved 2016-03-23.
  32. ^ "Dell kills off standalone DSSD D5, scatters remains into other gear". The Register.