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 Benchmarksfio: Rand Read - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Rand Read - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Seq Read - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Seq Read - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Seq Write - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Seq Write - IO_uring - Yes - No - 4KB - Default Test Directoryhbase: Seq Read - 32hbase: Seq Read - 32hbase: Async Rand Read - 32hbase: Async Rand Read - 32cassandra: Writesfio: Seq Read - IO_uring - Yes - No - 2MB - Default Test Directoryfio: Seq Read - IO_uring - Yes - No - 2MB - Default Test Directorysqlite: 1ior: Write Testleveldb: Fill Syncrocksdb: Read While Writingleveldb: Fill Syncleveldb: Rand Readrocksdb: Rand Readrocksdb: Rand Fillior: Read Testrocksdb: Seq Fillkeydb: hbase: Rand Read - 32hbase: Increment - 32hbase: Increment - 32leveldb: Seek Randhbase: Rand Read - 32build-gdb: Time To Compileleveldb: Overwriteleveldb: Seq Fillleveldb: Rand Deleteleveldb: Seq Fillleveldb: Overwriteleveldb: Rand Fillleveldb: Hot Readleveldb: Rand Fillbuild-gcc: Time To Compilehbase: Async Rand Write - 32hbase: Async Rand Write - 32rocksdb: Rand Fill Synccassandra: Mixed 1:1pgbench: Buffer Test - Normal Load - Read Writemysqlslap: 64fs-mark: 4000 Files, 32 Sub Dirs, 1MB Sizefs-mark: 5000 Files, 1MB Size, 4 Threadsfio: Seq Write - IO_uring - Yes - No - 2MB - Default Test Directoryfio: Seq Write - IO_uring - Yes - No - 2MB - Default Test Directoryfio: Rand Write - IO_uring - Yes - No - 4KB - Default Test Directoryfio: Rand Write - IO_uring - Yes - No - 4KB - Default Test Directorysqlite: 8NoneMQ-DeadlineKyberBFQ low-latencyBFQ1381353667379333148311843030001853451721881673712916273825190914.423797.731954.37661645353.641.2671813220241205145995.191235558519045.7613128711068066.58223996580.41126.727.5256.304257.331264.661265.43940.96226.7641.9905226137234082375334866.0822121134592.31238.2986197925066797944.7021119286333426000166511662986671701601871901660002712383967198014.385794.351966.91261842883.641.2951799969091185563977.231237822522808.4713128611091766.89023924480.24626.727.4257.507257.854265.354265.97541.01826.6641.408501637063120922612530.752488327591.4773.5847170124946797565.0651114285167493333192711552960001662031911791757462792524021200715.076781.431967.16161315303.641.0541833244541193020977.871216032527545.513028411146066.60924082180.36126.627.6257.428256.084265.715265.71940.89426.6642.181535601973371516512539.317088217545.8593.58841776226142883142.942787201600351333137310152600001774601791941625812737393792189314.718799.221998.43561161903.540.8111805173711188747978.411220974525133.3113028811019666.22924111480.89326.627.5257.174256.942265.547264.86641.05426.7642.189695464612976114112441.077629318590.6647.26861378240750940151.363800204500492000192110272630001733541841931636022828834009200114.598770.482019.66662942103.541.8191842328881178558986.321225970522119.6213228411173066.34023876980.79726.827.5258.148257.014264.245265.21241.06426.7642.042508627612327513712284.347087207528.4364.57031414245750960107.814OpenBenchmarking.org

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.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 DirectoryBFQ low-latencyBFQKyberMQ-DeadlineNone30060090012001500SE +/- 9.65, N = 5SE +/- 11.02, N = 4SE +/- 13.18, N = 6SE +/- 6.17, N = 3SE +/- 5.78, N = 37878001114111913811. (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 DirectoryBFQ low-latencyBFQKyberMQ-DeadlineNone80K160K240K320K400KSE +/- 2481.93, N = 5SE +/- 2843.12, N = 4SE +/- 3439.15, N = 6SE +/- 1763.83, N = 3SE +/- 1452.97, N = 32016002045002851672863333536671. (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: Sequential Read - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryBFQ low-latencyNoneMQ-DeadlineBFQKyber110K220K330K440K550KSE +/- 4176.65, N = 3SE +/- 1452.97, N = 3SE +/- 3214.55, N = 3SE +/- 6670.83, N = 4SE +/- 1666.67, N = 33513333793334260004920004933331. (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 DirectoryBFQ low-latencyNoneMQ-DeadlineBFQKyber400800120016002000SE +/- 16.23, N = 3SE +/- 5.81, N = 3SE +/- 12.35, N = 3SE +/- 26.11, N = 4SE +/- 7.17, N = 3137314831665192119271. (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 DirectoryBFQ low-latencyBFQKyberMQ-DeadlineNone30060090012001500SE +/- 13.20, N = 3SE +/- 15.25, N = 3SE +/- 8.11, N = 3SE +/- 11.84, N = 3SE +/- 10.45, N = 11101510271155116611841. (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: Sequential Write - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryBFQ low-latencyBFQKyberMQ-DeadlineNone60K120K180K240K300KSE +/- 3511.88, N = 3SE +/- 3785.94, N = 3SE +/- 2309.40, N = 3SE +/- 3179.80, N = 3SE +/- 2679.89, N = 112600002630002960002986673030001. (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.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Sequential Read - Clients: 32KyberMQ-DeadlineBFQBFQ low-latencyNone40K80K120K160K200KSE +/- 2793.36, N = 3SE +/- 2100.10, N = 15SE +/- 1398.50, N = 15SE +/- 2066.20, N = 15SE +/- 2136.52, N = 15166203170160173354177460185345

OpenBenchmarking.orgMicroseconds - Average Latency, Fewer Is BetterApache HBase 2.2.3Test: Sequential Read - Clients: 32KyberMQ-DeadlineBFQBFQ low-latencyNone4080120160200SE +/- 3.21, N = 3SE +/- 2.37, N = 15SE +/- 1.54, N = 15SE +/- 2.20, N = 15SE +/- 2.19, N = 15191187184179172

OpenBenchmarking.orgMicroseconds - Average Latency, Fewer Is BetterApache HBase 2.2.3Test: Async Random Read - Clients: 32BFQ low-latencyBFQMQ-DeadlineNoneKyber4080120160200SE +/- 1.76, N = 3SE +/- 2.19, N = 3SE +/- 2.33, N = 3SE +/- 1.86, N = 3SE +/- 2.03, N = 3194193190188179

OpenBenchmarking.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Async Random Read - Clients: 32BFQ low-latencyBFQMQ-DeadlineNoneKyber40K80K120K160K200KSE +/- 1743.02, N = 3SE +/- 1905.12, N = 3SE +/- 1862.94, N = 3SE +/- 1741.28, N = 3SE +/- 2062.43, N = 3162581163602166000167371175746

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: WritesMQ-DeadlineBFQ low-latencyKyberBFQNone60K120K180K240K300KSE +/- 3838.79, N = 3SE +/- 1752.30, N = 3SE +/- 2588.05, N = 15SE +/- 3156.44, N = 15SE +/- 4255.75, N = 3271238273739279252282883291627

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.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 DirectoryBFQ low-latencyNoneMQ-DeadlineBFQKyber9001800270036004500SE +/- 2.67, N = 3SE +/- 3.33, N = 3SE +/- 2.33, N = 3SE +/- 1.33, N = 3SE +/- 4.73, N = 3379238253967400940211. (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: Sequential Read - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 2MB - Disk Target: Default Test DirectoryBFQ low-latencyNoneMQ-DeadlineBFQKyber400800120016002000SE +/- 1.33, N = 3SE +/- 1.67, N = 3SE +/- 1.15, N = 3SE +/- 0.67, N = 3SE +/- 2.40, N = 3189319091980200120071. (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: 1KyberBFQ low-latencyBFQNoneMQ-Deadline48121620SE +/- 0.20, N = 15SE +/- 0.15, N = 8SE +/- 0.14, N = 3SE +/- 0.05, N = 3SE +/- 0.05, N = 315.0814.7214.6014.4214.391. (CC) gcc options: -O2 -lz -lm -ldl -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.1Write TestBFQKyberMQ-DeadlineNoneBFQ low-latency2004006008001000SE +/- 5.04, N = 3SE +/- 5.10, N = 3SE +/- 6.47, N = 3SE +/- 3.67, N = 3SE +/- 4.45, N = 3770.48781.43794.35797.73799.22MIN: 13.92 / MAX: 898.05MIN: 13.98 / MAX: 900.79MIN: 162.92 / MAX: 909.98MIN: 165.18 / MAX: 906.83MIN: 156.94 / MAX: 903.571. (CC) gcc options: -O2 -lm -pthread -lmpi

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 SyncBFQBFQ low-latencyKyberMQ-DeadlineNone400800120016002000SE +/- 19.00, N = 6SE +/- 19.30, N = 3SE +/- 13.46, N = 3SE +/- 5.68, N = 3SE +/- 3.92, N = 32019.671998.441967.161966.911954.381. (CXX) g++ options: -O3 -lsnappy -lpthread

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 WritingBFQ low-latencyKyberNoneMQ-DeadlineBFQ1.3M2.6M3.9M5.2M6.5MSE +/- 22104.21, N = 3SE +/- 21536.07, N = 3SE +/- 29916.58, N = 3SE +/- 80811.91, N = 5SE +/- 70731.04, N = 3611619061315306164535618428862942101. (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.orgMB/s, More Is BetterLevelDB 1.22Benchmark: Fill SyncBFQ low-latencyBFQNoneMQ-DeadlineKyber0.811.622.433.244.05SE +/- 0.06, N = 3SE +/- 0.04, N = 6SE +/- 0.00, N = 3SE +/- 0.03, N = 3SE +/- 0.03, N = 33.53.53.63.63.61. (CXX) g++ options: -O3 -lsnappy -lpthread

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

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 ReadMQ-DeadlineBFQ low-latencyNoneKyberBFQ40M80M120M160M200MSE +/- 1286835.14, N = 3SE +/- 2267118.09, N = 5SE +/- 2048541.15, N = 3SE +/- 3150233.61, N = 3SE +/- 2076338.73, N = 61799969091805173711813220241833244541842328881. (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: Random FillBFQMQ-DeadlineBFQ low-latencyKyberNone300K600K900K1200K1500KSE +/- 5909.18, N = 3SE +/- 11269.49, N = 3SE +/- 2824.61, N = 3SE +/- 2916.55, N = 3SE +/- 3276.95, N = 3117855811855631188747119302012051451. (CXX) g++ options: -O3 -march=native -std=c++11 -fno-builtin-memcmp -fno-rtti -rdynamic -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 TestMQ-DeadlineKyberBFQ low-latencyBFQNone2004006008001000SE +/- 1.94, N = 3SE +/- 5.68, N = 3SE +/- 5.02, N = 3SE +/- 2.94, N = 3SE +/- 0.64, N = 3977.23977.87978.41986.32995.19MIN: 746.57 / MAX: 1252.84MIN: 718.27 / MAX: 1337.12MIN: 724.27 / MAX: 1310.08MIN: 715.91 / MAX: 1357.45MIN: 727.61 / MAX: 1323.381. (CC) gcc options: -O2 -lm -pthread -lmpi

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: Sequential FillKyberBFQ low-latencyBFQNoneMQ-Deadline300K600K900K1200K1500KSE +/- 9197.27, N = 3SE +/- 3978.59, N = 3SE +/- 11522.86, N = 3SE +/- 9824.57, N = 3SE +/- 3005.09, N = 3121603212209741225970123555812378221. (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.1NoneBFQMQ-DeadlineBFQ low-latencyKyber110K220K330K440K550KSE +/- 3949.59, N = 3SE +/- 3207.20, N = 3SE +/- 5087.07, N = 3SE +/- 2938.61, N = 3SE +/- 2621.85, N = 3519045.76522119.62522808.47525133.31527545.501. (CXX) g++ options: -O2 -levent -lpthread -lz -lpcre

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: 32BFQMQ-DeadlineNoneBFQ low-latencyKyber306090120150SE +/- 0.67, N = 3SE +/- 0.67, N = 3132131131130130

OpenBenchmarking.orgMicroseconds - Average Latency, Fewer Is BetterApache HBase 2.2.3Test: Increment - Clients: 32BFQ low-latencyNoneMQ-DeadlineBFQKyber60120180240300SE +/- 1.45, N = 3SE +/- 2.19, N = 3SE +/- 2.89, N = 3SE +/- 1.86, N = 3288287286284284

OpenBenchmarking.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Increment - Clients: 32BFQ low-latencyNoneMQ-DeadlineKyberBFQ20K40K60K80K100KSE +/- 503.81, N = 3SE +/- 367.77, N = 3SE +/- 672.36, N = 3SE +/- 732.48, N = 3SE +/- 1065.86, N = 3110196110680110917111460111730

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 RandomMQ-DeadlineKyberNoneBFQBFQ low-latency1530456075SE +/- 0.04, N = 3SE +/- 0.11, N = 3SE +/- 0.15, N = 3SE +/- 0.07, N = 3SE +/- 0.24, N = 366.8966.6166.5866.3466.231. (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.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Random Read - Clients: 32BFQMQ-DeadlineNoneKyberBFQ low-latency50K100K150K200K250KSE +/- 1073.93, N = 3SE +/- 1696.17, N = 3SE +/- 1261.46, N = 3SE +/- 1147.34, N = 3SE +/- 1176.18, N = 3238769239244239965240821241114

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 CompileBFQ low-latencyBFQNoneKyberMQ-Deadline20406080100SE +/- 0.05, N = 3SE +/- 0.05, N = 3SE +/- 0.11, N = 3SE +/- 0.06, N = 3SE +/- 0.08, N = 380.8980.8080.4180.3680.25

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.orgMB/s, More Is BetterLevelDB 1.22Benchmark: OverwriteKyberBFQ low-latencyNoneMQ-DeadlineBFQ612182430SE +/- 0.12, N = 3SE +/- 0.06, N = 3SE +/- 0.09, N = 3SE +/- 0.07, N = 3SE +/- 0.07, N = 326.626.626.726.726.81. (CXX) g++ options: -O3 -lsnappy -lpthread

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

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

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

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

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

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

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

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 CompileBFQ low-latencyKyberBFQNoneMQ-Deadline140280420560700SE +/- 0.16, N = 3SE +/- 0.03, N = 3SE +/- 0.27, N = 3SE +/- 0.17, N = 3SE +/- 0.25, N = 3642.19642.18642.04641.99641.41

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: 32BFQ low-latencyKyberNoneBFQMQ-Deadline150300450600750SE +/- 24.46, N = 12SE +/- 16.45, N = 15SE +/- 13.83, N = 12SE +/- 3.48, N = 3SE +/- 6.18, N = 12695535522508501

OpenBenchmarking.orgRows Per Second, More Is BetterApache HBase 2.2.3Test: Async Random Write - Clients: 32BFQ low-latencyKyberNoneBFQMQ-Deadline14K28K42K56K70KSE +/- 1485.96, N = 12SE +/- 1589.78, N = 15SE +/- 1286.78, N = 12SE +/- 432.26, N = 3SE +/- 701.22, N = 124646160197613726276163706

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 SyncBFQBFQ low-latencyMQ-DeadlineKyberNone7K14K21K28K35KSE +/- 1587.48, N = 12SE +/- 810.82, N = 15SE +/- 842.51, N = 12SE +/- 138.08, N = 3SE +/- 159.25, N = 323275297613120933715340821. (CXX) g++ options: -O3 -march=native -std=c++11 -fno-builtin-memcmp -fno-rtti -rdynamic -lpthread

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:1BFQBFQ low-latencyKyberMQ-DeadlineNone8001600240032004000SE +/- 8.58, N = 6SE +/- 26.61, N = 6SE +/- 12.43, N = 7SE +/- 5.46, N = 9SE +/- 217.63, N = 91371411652263753

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 WriteBFQBFQ low-latencyMQ-DeadlineKyberNone7K14K21K28K35KSE +/- 162.47, N = 15SE +/- 212.09, N = 15SE +/- 170.74, N = 15SE +/- 139.65, N = 3SE +/- 238.48, N = 312284.3512441.0812530.7512539.3234866.081. (CC) gcc options: -fno-strict-aliasing -fwrapv -O2 -lpgcommon -lpgport -lpq -lpthread -lrt -lcrypt -ldl -lm

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: 64BFQKyberBFQ low-latencyMQ-DeadlineNone2004006008001000SE +/- 3.55, N = 3SE +/- 2.81, N = 3SE +/- 100.08, N = 9SE +/- 101.84, N = 9SE +/- 1.14, N = 320721731832711341. (CXX) g++ options: -pie -fPIC -fstack-protector -fno-rtti -O2 -lpthread -lsnappy -laio -lz -lm -lcrypt -lssl -lcrypto -ldl

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 SizeBFQKyberBFQ low-latencyMQ-DeadlineNone130260390520650SE +/- 21.50, N = 12SE +/- 24.28, N = 13SE +/- 1.70, N = 3SE +/- 2.75, N = 3SE +/- 0.97, N = 3528.4545.8590.6591.4592.31. (CC) gcc options: -static

OpenBenchmarking.orgFiles/s, More Is BetterFS-Mark 3.3Test: 5000 Files, 1MB Size, 4 ThreadsBFQKyberBFQ low-latencyMQ-DeadlineNone30060090012001500SE +/- 2.86, N = 3SE +/- 87.62, N = 12SE +/- 103.97, N = 12SE +/- 121.16, N = 12SE +/- 9.23, N = 3364.5593.5647.2773.51238.21. (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: Sequential Write - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 2MB - Disk Target: Default Test DirectoryBFQ low-latencyBFQMQ-DeadlineKyberNone2004006008001000SE +/- 68.36, N = 12SE +/- 49.26, N = 15SE +/- 27.25, N = 15SE +/- 36.75, N = 12SE +/- 10.37, N = 86867038478849861. (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 DirectoryBFQ low-latencyBFQMQ-DeadlineKyberNone400800120016002000SE +/- 136.82, N = 12SE +/- 98.56, N = 15SE +/- 54.46, N = 15SE +/- 73.55, N = 12SE +/- 20.59, N = 8137814141701177619791. (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 Write - Engine: IO_uring - Buffered: Yes - Direct: No - Block Size: 4KB - Disk Target: Default Test DirectoryKyberBFQ low-latencyBFQMQ-DeadlineNone50K100K150K200K250KSE +/- 14652.50, N = 12SE +/- 3250.00, N = 4SE +/- 4178.09, N = 12SE +/- 2212.23, N = 15SE +/- 2603.42, N = 32261422407502457502494672506671. (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 DirectoryKyberBFQ low-latencyBFQMQ-DeadlineNone2004006008001000SE +/- 57.22, N = 12SE +/- 12.91, N = 4SE +/- 16.31, N = 12SE +/- 8.60, N = 15SE +/- 10.41, N = 38839409609759791. (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: 8BFQ low-latencyKyberBFQMQ-DeadlineNone306090120150SE +/- 7.47, N = 12SE +/- 7.59, N = 12SE +/- 5.70, N = 15SE +/- 4.78, N = 15SE +/- 0.17, N = 3151.36142.94107.8165.0744.701. (CC) gcc options: -O2 -lz -lm -ldl -lpthread

52 Results Shown

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