Linux 5.6 IO Scheduler Benchmarks

Linux 5.6 I/O scheduler benchmarks on NVMe SSD. Benchmarks by Michael Larabel for a future article.

Compare your own system(s) to this result file with the Phoronix Test Suite by running the command: phoronix-test-suite benchmark 2003265-NI-LINUX56IO44
Jump To Table - Results

View

Do Not Show Noisy Results
Do Not Show Results With Incomplete Data
Do Not Show Results With Little Change/Spread
List Notable Results
Show Result Confidence Charts
Allow Limiting Results To Certain Suite(s)

Statistics

Show Overall Harmonic Mean(s)
Show Overall Geometric Mean
Show Wins / Losses Counts (Pie Chart)
Normalize Results
Remove Outliers Before Calculating Averages

Graph Settings

Force Line Graphs Where Applicable
Convert To Scalar Where Applicable
Prefer Vertical Bar Graphs

Multi-Way Comparison

Condense Multi-Option Tests Into Single Result Graphs

Table

Show Detailed System Result Table

Run Management

Highlight
Result
Toggle/Hide
Result
Result
Identifier
View Logs
Performance Per
Dollar
Date
Run
  Test
  Duration
None
March 23 2020
  4 Hours
MQ-Deadline
March 23 2020
  8 Hours, 19 Minutes
Kyber
March 24 2020
  6 Hours, 57 Minutes
BFQ low-latency
March 24 2020
  8 Hours, 23 Minutes
BFQ
March 25 2020
  6 Hours, 51 Minutes
Invert Behavior (Only Show Selected Data)
  6 Hours, 54 Minutes

Only show results where is faster than
Only show results matching title/arguments (delimit multiple options with a comma):
Do not show results matching title/arguments (delimit multiple options with a comma):


Linux 5.6 IO Scheduler BenchmarksOpenBenchmarking.orgPhoronix Test SuiteAMD Ryzen Threadripper 3970X 32-Core @ 3.70GHz (32 Cores / 64 Threads)ASUS ROG ZENITH II EXTREME (0702 BIOS)AMD Starship/Matisse64GB1000GB Force MP600Gigabyte AMD Radeon RX 5500/5500M / Pro 5500M 8GB (1890/875MHz)AMD Navi 10 HDMI AudioASUS MG28UAquantia AQC107 NBase-T/IEEE + Intel I211 + Intel Wi-Fi 6 AX200Ubuntu 20.045.6.0-050600rc7-generic (x86_64) 20200322GNOME Shell 3.35.91X Server 1.20.7modesetting 1.20.74.6 Mesa 20.0.0 (LLVM 9.0.1)GCC 9.3.0ext41280x8003840x2160ProcessorMotherboardChipsetMemoryDiskGraphicsAudioMonitorNetworkOSKernelDesktopDisplay ServerDisplay DriverOpenGLCompilerFile-SystemScreen ResolutionsLinux 5.6 IO Scheduler Benchmarks PerformanceSystem Logs- --build=x86_64-linux-gnu --disable-vtable-verify --disable-werror --enable-checking=release --enable-clocale=gnu --enable-default-pie --enable-gnu-unique-object --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++,gm2 --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-multiarch --enable-multilib --enable-nls --enable-objc-gc=auto --enable-offload-targets=nvptx-none,hsa --enable-plugin --enable-shared --enable-threads=posix --host=x86_64-linux-gnu --program-prefix=x86_64-linux-gnu- --target=x86_64-linux-gnu --with-abi=m64 --with-arch-32=i686 --with-default-libstdcxx-abi=new --with-gcc-major-version-only --with-multilib-list=m32,m64,mx32 --with-target-system-zlib=auto --with-tune=generic --without-cuda-driver -v - None: NONE / errors=remount-ro,relatime,rw- MQ-Deadline: MQ-DEADLINE / errors=remount-ro,relatime,rw- Kyber: KYBER / errors=remount-ro,relatime,rw- BFQ low-latency: BFQ / errors=remount-ro,relatime,rw- BFQ: BFQ / errors=remount-ro,relatime,rw- Scaling Governor: acpi-cpufreq ondemand - CPU Microcode: 0x8301025- OpenJDK Runtime Environment (build 11.0.6+10-post-Ubuntu-2ubuntu2)- itlb_multihit: Not affected + l1tf: Not affected + mds: Not affected + meltdown: Not affected + spec_store_bypass: Mitigation of SSB disabled via prctl and seccomp + spectre_v1: Mitigation of usercopy/swapgs barriers and __user pointer sanitization + spectre_v2: Mitigation of Full AMD retpoline IBPB: conditional STIBP: conditional RSB filling + tsx_async_abort: Not affected

NoneMQ-DeadlineKyberBFQ low-latencyBFQLogarithmic Result OverviewPhoronix Test SuiteMariaDBApache CassandraPostgreSQL pgbenchFS-MarkSQLiteFlexible IO TesterFacebook RocksDBApache HBaseIORKeyDBTimed GDB GNU Debugger CompilationLevelDBTimed GCC Compilation

Linux 5.6 IO Scheduler Benchmarksmysqlslap: 64cassandra: Mixed 1:1build-gcc: Time To Compilesqlite: 8hbase: Async Rand Write - 32hbase: Async Rand Write - 32pgbench: Buffer Test - Normal Load - Read Writecassandra: Writesrocksdb: Rand Fill Synchbase: Seq Read - 32hbase: Seq Read - 32fio: Seq Write - IO_uring - Yes - No - 2MB - Default Test Directoryfio: Seq Write - IO_uring - Yes - No - 2MB - Default Test Directoryleveldb: Rand Deleteleveldb: Seq Fillleveldb: Seq Fillfs-mark: 5000 Files, 1MB Size, 4 Threadsfio: Rand Write - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Rand Write - IO_uring - Yes - No - 4KB - Default Test Directorybuild-gdb: Time To Compilerocksdb: Rand Readkeydb: rocksdb: Read While Writingleveldb: Seek Randhbase: Increment - 32hbase: Increment - 32rocksdb: Rand Fillrocksdb: Seq Fillfio: Seq Write - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Seq Write - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Rand Read - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Rand Read - IO_uring - Yes - No - 4KB - Default Test Directoryleveldb: Rand Readhbase: Async Rand Read - 32hbase: Async Rand Read - 32leveldb: Hot Readfio: Seq Read - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Seq Read - IO_uring - Yes - No - 4KB - Default Test Directorysqlite: 1fio: Seq Read - IO_uring - Yes - No - 2MB - Default Test Directoryfio: Seq Read - IO_uring - Yes - No - 2MB - Default Test Directoryhbase: Rand Read - 32hbase: Rand Read - 32leveldb: Rand Fillleveldb: Rand Fillleveldb: Overwriteleveldb: Overwritefs-mark: 4000 Files, 32 Sub Dirs, 1MB Sizeleveldb: Fill Syncleveldb: Fill Syncior: Read Testior: Write TestNoneMQ-DeadlineKyberBFQ low-latencyBFQ11343753641.99044.7025226137234866.082212291627340821721853459861979256.304257.33127.51238.225066797980.411181322024519045.76616453566.582287110680120514512355583030001184353667138141.26718816737140.962379333148314.42319093825131239965265.43926.7264.66126.7592.31954.3763.6995.19797.73327226641.40865.0655016370612530.752488271238312091871701608471701257.507257.85427.4773.524946797580.246179996909522808.47618428866.890286110917118556312378222986671166286333111941.29519016600041.018426000166514.38519803967131239244265.97526.6265.35426.7591.41966.9123.6977.23794.35217165642.181142.9425356019712539.317088279252337151911662038841776257.428256.08427.6593.522614288380.361183324454527545.5613153066.609284111460119302012160322960001155285167111441.05417917574640.894493333192715.07620074021130240821265.71926.6265.71526.6545.81967.1613.6977.87781.43318141642.189151.3636954646112441.077629273739297611791774606861378257.174256.94227.5647.224075094080.893180517371525133.31611619066.22928811019611887471220974260000101520160078740.81119416258141.054351333137314.71818933792130241114264.86626.7265.54726.6590.61998.4353.5978.41799.22207137642.042107.8145086276112284.347087282883232751841733547031414258.148257.01427.5364.524575096080.797184232888522119.62629421066.34028411173011785581225970263000102720450080041.81919316360241.064492000192114.59820014009132238769265.21226.7264.24526.8528.42019.6663.5986.32770.48OpenBenchmarking.org

MariaDB

This is a MariaDB MySQL database server benchmark making use of mysqlslap. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgQueries Per Second, More Is BetterMariaDB 10.3.8Clients: 64NoneMQ-DeadlineKyberBFQ low-latencyBFQ2004006008001000SE +/- 1.14, N = 3SE +/- 101.84, N = 9SE +/- 2.81, N = 3SE +/- 100.08, N = 9SE +/- 3.55, N = 311343272173182071. (CXX) g++ options: -pie -fPIC -fstack-protector -fno-rtti -O2 -lpthread -lsnappy -laio -lz -lm -lcrypt -lssl -lcrypto -ldl

Apache Cassandra

This is a benchmark of the Apache Cassandra NoSQL database management system making use of cassandra-stress. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgOp/s, More Is BetterApache Cassandra 3.11.4Test: Mixed 1:1NoneMQ-DeadlineKyberBFQ low-latencyBFQ8001600240032004000SE +/- 217.63, N = 9SE +/- 5.46, N = 9SE +/- 12.43, N = 7SE +/- 26.61, N = 6SE +/- 8.58, N = 63753226165141137

Timed GCC Compilation

This test times how long it takes to build the GNU Compiler Collection (GCC). Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgSeconds, Fewer Is BetterTimed GCC Compilation 9.3.0Time To CompileNoneMQ-DeadlineKyberBFQ low-latencyBFQ140280420560700SE +/- 0.17, N = 3SE +/- 0.25, N = 3SE +/- 0.03, N = 3SE +/- 0.16, N = 3SE +/- 0.27, N = 3641.99641.41642.18642.19642.04

SQLite

This is a simple benchmark of SQLite. At present this test profile just measures the time to perform a pre-defined number of insertions on an indexed database. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgSeconds, Fewer Is BetterSQLite 3.30.1Threads / Copies: 8NoneMQ-DeadlineKyberBFQ low-latencyBFQ306090120150SE +/- 0.17, N = 3SE +/- 4.78, N = 15SE +/- 7.59, N = 12SE +/- 7.47, N = 12SE +/- 5.70, N = 1544.7065.07142.94151.36107.811. (CC) gcc options: -O2 -lz -lm -ldl -lpthread

Apache HBase

This is a benchmark of the Apache HBase non-relational distributed database system inspired from Google's Bigtable. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds - Average Latency, Fewer Is BetterApache HBase 2.2.3Test: Async Random Write - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ150300450600750SE +/- 13.83, N = 12SE +/- 6.18, N = 12SE +/- 16.45, N = 15SE +/- 24.46, N = 12SE +/- 3.48, N = 3522501535695508

OpenBenchmarking.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Async Random Write - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ14K28K42K56K70KSE +/- 1286.78, N = 12SE +/- 701.22, N = 12SE +/- 1589.78, N = 15SE +/- 1485.96, N = 12SE +/- 432.26, N = 36137263706601974646162761

PostgreSQL pgbench

This is a simple benchmark of PostgreSQL using pgbench. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgTPS, More Is BetterPostgreSQL pgbench 12.0Scaling: Buffer Test - Test: Normal Load - Mode: Read WriteNoneMQ-DeadlineKyberBFQ low-latencyBFQ7K14K21K28K35KSE +/- 238.48, N = 3SE +/- 170.74, N = 15SE +/- 139.65, N = 3SE +/- 212.09, N = 15SE +/- 162.47, N = 1534866.0812530.7512539.3212441.0812284.351. (CC) gcc options: -fno-strict-aliasing -fwrapv -O2 -lpgcommon -lpgport -lpq -lpthread -lrt -lcrypt -ldl -lm

Apache Cassandra

This is a benchmark of the Apache Cassandra NoSQL database management system making use of cassandra-stress. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgOp/s, More Is BetterApache Cassandra 3.11.4Test: WritesNoneMQ-DeadlineKyberBFQ low-latencyBFQ60K120K180K240K300KSE +/- 4255.75, N = 3SE +/- 3838.79, N = 3SE +/- 2588.05, N = 15SE +/- 1752.30, N = 3SE +/- 3156.44, N = 15291627271238279252273739282883

Facebook RocksDB

This is a benchmark of Facebook's RocksDB as an embeddable persistent key-value store for fast storage based on Google's LevelDB. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgOp/s, More Is BetterFacebook RocksDB 6.3.6Test: Random Fill SyncNoneMQ-DeadlineKyberBFQ low-latencyBFQ7K14K21K28K35KSE +/- 159.25, N = 3SE +/- 842.51, N = 12SE +/- 138.08, N = 3SE +/- 810.82, N = 15SE +/- 1587.48, N = 1234082312093371529761232751. (CXX) g++ options: -O3 -march=native -std=c++11 -fno-builtin-memcmp -fno-rtti -rdynamic -lpthread

Apache HBase

This is a benchmark of the Apache HBase non-relational distributed database system inspired from Google's Bigtable. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds - Average Latency, Fewer Is BetterApache HBase 2.2.3Test: Sequential Read - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ4080120160200SE +/- 2.19, N = 15SE +/- 2.37, N = 15SE +/- 3.21, N = 3SE +/- 2.20, N = 15SE +/- 1.54, N = 15172187191179184

OpenBenchmarking.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Sequential Read - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ40K80K120K160K200KSE +/- 2136.52, N = 15SE +/- 2100.10, N = 15SE +/- 2793.36, N = 3SE +/- 2066.20, N = 15SE +/- 1398.50, N = 15185345170160166203177460173354

Flexible IO Tester

Fio is an advanced disk benchmark that depends upon the kernel's AIO access library. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 3.18Type: Sequential Write - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 2MB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ2004006008001000SE +/- 10.37, N = 8SE +/- 27.25, N = 15SE +/- 36.75, N = 12SE +/- 68.36, N = 12SE +/- 49.26, N = 159868478846867031. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 3.18Type: Sequential Write - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 2MB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ400800120016002000SE +/- 20.59, N = 8SE +/- 54.46, N = 15SE +/- 73.55, N = 12SE +/- 136.82, N = 12SE +/- 98.56, N = 15197917011776137814141. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

LevelDB

LevelDB is a key-value storage library developed by Google that supports making use of Snappy for data compression and has other modern features. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds Per Op, Fewer Is BetterLevelDB 1.22Benchmark: Random DeleteNoneMQ-DeadlineKyberBFQ low-latencyBFQ60120180240300SE +/- 0.66, N = 3SE +/- 0.58, N = 3SE +/- 0.37, N = 3SE +/- 0.13, N = 3SE +/- 0.64, N = 3256.30257.51257.43257.17258.151. (CXX) g++ options: -O3 -lsnappy -lpthread

OpenBenchmarking.orgMicroseconds Per Op, Fewer Is BetterLevelDB 1.22Benchmark: Sequential FillNoneMQ-DeadlineKyberBFQ low-latencyBFQ60120180240300SE +/- 0.55, N = 3SE +/- 0.41, N = 3SE +/- 0.53, N = 3SE +/- 0.62, N = 3SE +/- 0.62, N = 3257.33257.85256.08256.94257.011. (CXX) g++ options: -O3 -lsnappy -lpthread

OpenBenchmarking.orgMB/s, More Is BetterLevelDB 1.22Benchmark: Sequential FillNoneMQ-DeadlineKyberBFQ low-latencyBFQ612182430SE +/- 0.06, N = 3SE +/- 0.03, N = 3SE +/- 0.07, N = 3SE +/- 0.07, N = 3SE +/- 0.09, N = 327.527.427.627.527.51. (CXX) g++ options: -O3 -lsnappy -lpthread

FS-Mark

FS_Mark is designed to test a system's file-system performance. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgFiles/s, More Is BetterFS-Mark 3.3Test: 5000 Files, 1MB Size, 4 ThreadsNoneMQ-DeadlineKyberBFQ low-latencyBFQ30060090012001500SE +/- 9.23, N = 3SE +/- 121.16, N = 12SE +/- 87.62, N = 12SE +/- 103.97, N = 12SE +/- 2.86, N = 31238.2773.5593.5647.2364.51. (CC) gcc options: -static

Flexible IO Tester

Fio is an advanced disk benchmark that depends upon the kernel's AIO access library. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 3.18Type: Random Write - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ50K100K150K200K250KSE +/- 2603.42, N = 3SE +/- 2212.23, N = 15SE +/- 14652.50, N = 12SE +/- 3250.00, N = 4SE +/- 4178.09, N = 122506672494672261422407502457501. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 3.18Type: Random Write - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ2004006008001000SE +/- 10.41, N = 3SE +/- 8.60, N = 15SE +/- 57.22, N = 12SE +/- 12.91, N = 4SE +/- 16.31, N = 129799758839409601. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

Timed GDB GNU Debugger Compilation

This test times how long it takes to build the GNU Debugger (GDB) in a default configuration. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgSeconds, Fewer Is BetterTimed GDB GNU Debugger Compilation 9.1Time To CompileNoneMQ-DeadlineKyberBFQ low-latencyBFQ20406080100SE +/- 0.11, N = 3SE +/- 0.08, N = 3SE +/- 0.06, N = 3SE +/- 0.05, N = 3SE +/- 0.05, N = 380.4180.2580.3680.8980.80

Facebook RocksDB

This is a benchmark of Facebook's RocksDB as an embeddable persistent key-value store for fast storage based on Google's LevelDB. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgOp/s, More Is BetterFacebook RocksDB 6.3.6Test: Random ReadNoneMQ-DeadlineKyberBFQ low-latencyBFQ40M80M120M160M200MSE +/- 2048541.15, N = 3SE +/- 1286835.14, N = 3SE +/- 3150233.61, N = 3SE +/- 2267118.09, N = 5SE +/- 2076338.73, N = 61813220241799969091833244541805173711842328881. (CXX) g++ options: -O3 -march=native -std=c++11 -fno-builtin-memcmp -fno-rtti -rdynamic -lpthread

KeyDB

A benchmark of KeyDB as a multi-threaded fork of the Redis server. The KeyDB benchmark is conducted using memtier-benchmark. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgOps/sec, More Is BetterKeyDB 5.3.1NoneMQ-DeadlineKyberBFQ low-latencyBFQ110K220K330K440K550KSE +/- 3949.59, N = 3SE +/- 5087.07, N = 3SE +/- 2621.85, N = 3SE +/- 2938.61, N = 3SE +/- 3207.20, N = 3519045.76522808.47527545.50525133.31522119.621. (CXX) g++ options: -O2 -levent -lpthread -lz -lpcre

Facebook RocksDB

This is a benchmark of Facebook's RocksDB as an embeddable persistent key-value store for fast storage based on Google's LevelDB. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgOp/s, More Is BetterFacebook RocksDB 6.3.6Test: Read While WritingNoneMQ-DeadlineKyberBFQ low-latencyBFQ1.3M2.6M3.9M5.2M6.5MSE +/- 29916.58, N = 3SE +/- 80811.91, N = 5SE +/- 21536.07, N = 3SE +/- 22104.21, N = 3SE +/- 70731.04, N = 3616453561842886131530611619062942101. (CXX) g++ options: -O3 -march=native -std=c++11 -fno-builtin-memcmp -fno-rtti -rdynamic -lpthread

LevelDB

LevelDB is a key-value storage library developed by Google that supports making use of Snappy for data compression and has other modern features. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds Per Op, Fewer Is BetterLevelDB 1.22Benchmark: Seek RandomNoneMQ-DeadlineKyberBFQ low-latencyBFQ1530456075SE +/- 0.15, N = 3SE +/- 0.04, N = 3SE +/- 0.11, N = 3SE +/- 0.24, N = 3SE +/- 0.07, N = 366.5866.8966.6166.2366.341. (CXX) g++ options: -O3 -lsnappy -lpthread

Apache HBase

This is a benchmark of the Apache HBase non-relational distributed database system inspired from Google's Bigtable. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds - Average Latency, Fewer Is BetterApache HBase 2.2.3Test: Increment - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ60120180240300SE +/- 1.45, N = 3SE +/- 2.19, N = 3SE +/- 1.86, N = 3SE +/- 2.89, N = 3287286284288284

OpenBenchmarking.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Increment - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ20K40K60K80K100KSE +/- 367.77, N = 3SE +/- 672.36, N = 3SE +/- 732.48, N = 3SE +/- 503.81, N = 3SE +/- 1065.86, N = 3110680110917111460110196111730

Facebook RocksDB

This is a benchmark of Facebook's RocksDB as an embeddable persistent key-value store for fast storage based on Google's LevelDB. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgOp/s, More Is BetterFacebook RocksDB 6.3.6Test: Random FillNoneMQ-DeadlineKyberBFQ low-latencyBFQ300K600K900K1200K1500KSE +/- 3276.95, N = 3SE +/- 11269.49, N = 3SE +/- 2916.55, N = 3SE +/- 2824.61, N = 3SE +/- 5909.18, N = 3120514511855631193020118874711785581. (CXX) g++ options: -O3 -march=native -std=c++11 -fno-builtin-memcmp -fno-rtti -rdynamic -lpthread

OpenBenchmarking.orgOp/s, More Is BetterFacebook RocksDB 6.3.6Test: Sequential FillNoneMQ-DeadlineKyberBFQ low-latencyBFQ300K600K900K1200K1500KSE +/- 9824.57, N = 3SE +/- 3005.09, N = 3SE +/- 9197.27, N = 3SE +/- 3978.59, N = 3SE +/- 11522.86, N = 3123555812378221216032122097412259701. (CXX) g++ options: -O3 -march=native -std=c++11 -fno-builtin-memcmp -fno-rtti -rdynamic -lpthread

Flexible IO Tester

Fio is an advanced disk benchmark that depends upon the kernel's AIO access library. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 3.18Type: Sequential Write - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ60K120K180K240K300KSE +/- 2679.89, N = 11SE +/- 3179.80, N = 3SE +/- 2309.40, N = 3SE +/- 3511.88, N = 3SE +/- 3785.94, N = 33030002986672960002600002630001. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 3.18Type: Sequential Write - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ30060090012001500SE +/- 10.45, N = 11SE +/- 11.84, N = 3SE +/- 8.11, N = 3SE +/- 13.20, N = 3SE +/- 15.25, N = 3118411661155101510271. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 3.18Type: Random Read - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ80K160K240K320K400KSE +/- 1452.97, N = 3SE +/- 1763.83, N = 3SE +/- 3439.15, N = 6SE +/- 2481.93, N = 5SE +/- 2843.12, N = 43536672863332851672016002045001. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 3.18Type: Random Read - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ30060090012001500SE +/- 5.78, N = 3SE +/- 6.17, N = 3SE +/- 13.18, N = 6SE +/- 9.65, N = 5SE +/- 11.02, N = 41381111911147878001. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

LevelDB

LevelDB is a key-value storage library developed by Google that supports making use of Snappy for data compression and has other modern features. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds Per Op, Fewer Is BetterLevelDB 1.22Benchmark: Random ReadNoneMQ-DeadlineKyberBFQ low-latencyBFQ1020304050SE +/- 0.15, N = 3SE +/- 0.18, N = 3SE +/- 0.09, N = 3SE +/- 0.15, N = 3SE +/- 0.44, N = 341.2741.3041.0540.8141.821. (CXX) g++ options: -O3 -lsnappy -lpthread

Apache HBase

This is a benchmark of the Apache HBase non-relational distributed database system inspired from Google's Bigtable. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds - Average Latency, Fewer Is BetterApache HBase 2.2.3Test: Async Random Read - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ4080120160200SE +/- 1.86, N = 3SE +/- 2.33, N = 3SE +/- 2.03, N = 3SE +/- 1.76, N = 3SE +/- 2.19, N = 3188190179194193

OpenBenchmarking.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Async Random Read - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ40K80K120K160K200KSE +/- 1741.28, N = 3SE +/- 1862.94, N = 3SE +/- 2062.43, N = 3SE +/- 1743.02, N = 3SE +/- 1905.12, N = 3167371166000175746162581163602

LevelDB

LevelDB is a key-value storage library developed by Google that supports making use of Snappy for data compression and has other modern features. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds Per Op, Fewer Is BetterLevelDB 1.22Benchmark: Hot ReadNoneMQ-DeadlineKyberBFQ low-latencyBFQ918273645SE +/- 0.21, N = 3SE +/- 0.16, N = 3SE +/- 0.14, N = 3SE +/- 0.18, N = 3SE +/- 0.26, N = 340.9641.0240.8941.0541.061. (CXX) g++ options: -O3 -lsnappy -lpthread

Flexible IO Tester

Fio is an advanced disk benchmark that depends upon the kernel's AIO access library. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 3.18Type: Sequential Read - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ110K220K330K440K550KSE +/- 1452.97, N = 3SE +/- 3214.55, N = 3SE +/- 1666.67, N = 3SE +/- 4176.65, N = 3SE +/- 6670.83, N = 43793334260004933333513334920001. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 3.18Type: Sequential Read - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ400800120016002000SE +/- 5.81, N = 3SE +/- 12.35, N = 3SE +/- 7.17, N = 3SE +/- 16.23, N = 3SE +/- 26.11, N = 4148316651927137319211. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

SQLite

This is a simple benchmark of SQLite. At present this test profile just measures the time to perform a pre-defined number of insertions on an indexed database. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgSeconds, Fewer Is BetterSQLite 3.30.1Threads / Copies: 1NoneMQ-DeadlineKyberBFQ low-latencyBFQ48121620SE +/- 0.05, N = 3SE +/- 0.05, N = 3SE +/- 0.20, N = 15SE +/- 0.15, N = 8SE +/- 0.14, N = 314.4214.3915.0814.7214.601. (CC) gcc options: -O2 -lz -lm -ldl -lpthread

Flexible IO Tester

Fio is an advanced disk benchmark that depends upon the kernel's AIO access library. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 3.18Type: Sequential Read - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 2MB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ400800120016002000SE +/- 1.67, N = 3SE +/- 1.15, N = 3SE +/- 2.40, N = 3SE +/- 1.33, N = 3SE +/- 0.67, N = 3190919802007189320011. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 3.18Type: Sequential Read - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 2MB - Disk Target: Default Test DirectoryNoneMQ-DeadlineKyberBFQ low-latencyBFQ9001800270036004500SE +/- 3.33, N = 3SE +/- 2.33, N = 3SE +/- 4.73, N = 3SE +/- 2.67, N = 3SE +/- 1.33, N = 3382539674021379240091. (CC) gcc options: -rdynamic -std=gnu99 -ffast-math -include -O3 -U_FORTIFY_SOURCE -march=native -ll -lrt -laio -lz -lpthread -lm -ldl

Apache HBase

This is a benchmark of the Apache HBase non-relational distributed database system inspired from Google's Bigtable. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds - Average Latency, Fewer Is BetterApache HBase 2.2.3Test: Random Read - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ306090120150SE +/- 0.67, N = 3SE +/- 0.67, N = 3131131130130132

OpenBenchmarking.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Random Read - Clients: 32NoneMQ-DeadlineKyberBFQ low-latencyBFQ50K100K150K200K250KSE +/- 1261.46, N = 3SE +/- 1696.17, N = 3SE +/- 1147.34, N = 3SE +/- 1176.18, N = 3SE +/- 1073.93, N = 3239965239244240821241114238769

LevelDB

LevelDB is a key-value storage library developed by Google that supports making use of Snappy for data compression and has other modern features. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds Per Op, Fewer Is BetterLevelDB 1.22Benchmark: Random FillNoneMQ-DeadlineKyberBFQ low-latencyBFQ60120180240300SE +/- 0.41, N = 3SE +/- 0.87, N = 3SE +/- 0.64, N = 3SE +/- 0.15, N = 3SE +/- 0.38, N = 3265.44265.98265.72264.87265.211. (CXX) g++ options: -O3 -lsnappy -lpthread

OpenBenchmarking.orgMB/s, More Is BetterLevelDB 1.22Benchmark: Random FillNoneMQ-DeadlineKyberBFQ low-latencyBFQ612182430SE +/- 0.03, N = 3SE +/- 0.09, N = 3SE +/- 0.07, N = 3SE +/- 0.00, N = 3SE +/- 0.03, N = 326.726.626.626.726.71. (CXX) g++ options: -O3 -lsnappy -lpthread

OpenBenchmarking.orgMicroseconds Per Op, Fewer Is BetterLevelDB 1.22Benchmark: OverwriteNoneMQ-DeadlineKyberBFQ low-latencyBFQ60120180240300SE +/- 0.82, N = 3SE +/- 0.58, N = 3SE +/- 1.16, N = 3SE +/- 0.56, N = 3SE +/- 0.58, N = 3264.66265.35265.72265.55264.251. (CXX) g++ options: -O3 -lsnappy -lpthread

OpenBenchmarking.orgMB/s, More Is BetterLevelDB 1.22Benchmark: OverwriteNoneMQ-DeadlineKyberBFQ low-latencyBFQ612182430SE +/- 0.09, N = 3SE +/- 0.07, N = 3SE +/- 0.12, N = 3SE +/- 0.06, N = 3SE +/- 0.07, N = 326.726.726.626.626.81. (CXX) g++ options: -O3 -lsnappy -lpthread

FS-Mark

FS_Mark is designed to test a system's file-system performance. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgFiles/s, More Is BetterFS-Mark 3.3Test: 4000 Files, 32 Sub Dirs, 1MB SizeNoneMQ-DeadlineKyberBFQ low-latencyBFQ130260390520650SE +/- 0.97, N = 3SE +/- 2.75, N = 3SE +/- 24.28, N = 13SE +/- 1.70, N = 3SE +/- 21.50, N = 12592.3591.4545.8590.6528.41. (CC) gcc options: -static

LevelDB

LevelDB is a key-value storage library developed by Google that supports making use of Snappy for data compression and has other modern features. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMicroseconds Per Op, Fewer Is BetterLevelDB 1.22Benchmark: Fill SyncNoneMQ-DeadlineKyberBFQ low-latencyBFQ400800120016002000SE +/- 3.92, N = 3SE +/- 5.68, N = 3SE +/- 13.46, N = 3SE +/- 19.30, N = 3SE +/- 19.00, N = 61954.381966.911967.161998.442019.671. (CXX) g++ options: -O3 -lsnappy -lpthread

OpenBenchmarking.orgMB/s, More Is BetterLevelDB 1.22Benchmark: Fill SyncNoneMQ-DeadlineKyberBFQ low-latencyBFQ0.811.622.433.244.05SE +/- 0.00, N = 3SE +/- 0.03, N = 3SE +/- 0.03, N = 3SE +/- 0.06, N = 3SE +/- 0.04, N = 63.63.63.63.53.51. (CXX) g++ options: -O3 -lsnappy -lpthread

IOR

IOR is a parallel I/O storage benchmark. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMB/s, More Is BetterIOR 3.2.1Read TestNoneMQ-DeadlineKyberBFQ low-latencyBFQ2004006008001000SE +/- 0.64, N = 3SE +/- 1.94, N = 3SE +/- 5.68, N = 3SE +/- 5.02, N = 3SE +/- 2.94, N = 3995.19977.23977.87978.41986.32MIN: 727.61 / MAX: 1323.38MIN: 746.57 / MAX: 1252.84MIN: 718.27 / MAX: 1337.12MIN: 724.27 / MAX: 1310.08MIN: 715.91 / MAX: 1357.451. (CC) gcc options: -O2 -lm -pthread -lmpi

OpenBenchmarking.orgMB/s, More Is BetterIOR 3.2.1Write TestNoneMQ-DeadlineKyberBFQ low-latencyBFQ2004006008001000SE +/- 3.67, N = 3SE +/- 6.47, N = 3SE +/- 5.10, N = 3SE +/- 4.45, N = 3SE +/- 5.04, N = 3797.73794.35781.43799.22770.48MIN: 165.18 / MAX: 906.83MIN: 162.92 / MAX: 909.98MIN: 13.98 / MAX: 900.79MIN: 156.94 / MAX: 903.57MIN: 13.92 / MAX: 898.051. (CC) gcc options: -O2 -lm -pthread -lmpi

52 Results Shown

MariaDB
Apache Cassandra
Timed GCC Compilation
SQLite
Apache HBase:
  Async Rand Write - 32:
    Microseconds - Average Latency
    Rows Per Second
PostgreSQL pgbench
Apache Cassandra
Facebook RocksDB
Apache HBase:
  Seq Read - 32:
    Microseconds - Average Latency
    Rows Per Second
Flexible IO Tester:
  Seq Write - IO_uring - Yes - No - 2MB - Default Test Directory:
    IOPS
    MB/s
LevelDB:
  Rand Delete
  Seq Fill
  Seq Fill
FS-Mark
Flexible IO Tester:
  Rand Write - IO_uring - Yes - No - 4KB - Default Test Directory:
    IOPS
    MB/s
Timed GDB GNU Debugger Compilation
Facebook RocksDB
KeyDB
Facebook RocksDB
LevelDB
Apache HBase:
  Increment - 32:
    Microseconds - Average Latency
    Rows Per Second
Facebook RocksDB:
  Rand Fill
  Seq Fill
Flexible IO Tester:
  Seq Write - IO_uring - Yes - No - 4KB - Default Test Directory:
    IOPS
    MB/s
  Rand Read - IO_uring - Yes - No - 4KB - Default Test Directory:
    IOPS
    MB/s
LevelDB
Apache HBase:
  Async Rand Read - 32:
    Microseconds - Average Latency
    Rows Per Second
LevelDB
Flexible IO Tester:
  Seq Read - IO_uring - Yes - No - 4KB - Default Test Directory:
    IOPS
    MB/s
SQLite
Flexible IO Tester:
  Seq Read - IO_uring - Yes - No - 2MB - Default Test Directory:
    IOPS
    MB/s
Apache HBase:
  Rand Read - 32:
    Microseconds - Average Latency
    Rows Per Second
LevelDB:
  Rand Fill:
    Microseconds Per Op
    MB/s
  Overwrite:
    Microseconds Per Op
    MB/s
FS-Mark
LevelDB:
  Fill Sync:
    Microseconds Per Op
    MB/s
IOR:
  Read Test
  Write Test