GitXplorerGitXplorer
p

ioarena

public
134 stars
24 forks
8 issues

Commits

List of commits on branch master.
Unverified
dfb5a08121292b88de396ba97744bf782c335cf8

* iowow: update submodule to v1.4.11-2

aadamansky committed 4 years ago
Unverified
96a1456cceb34643b9617484ec266387866c8b77

* iowow: update submodule to v1.4.12

aadamansky committed 4 years ago
Verified
15aab2b058580984701ba2ed00eb2605e9ed2a2a

Merge pull request #42 from erthink/master

ppmwkaa committed 4 years ago
Unverified
1d423d423dcdafab9417a8672f939d7dddcb285e

ioarena: fix missing a few config fields initialization (minor).

eerthink committed 4 years ago
Unverified
10e7b16021f5f153cb3b18970dff1f162e73ea33

ioarena: verbose `batch length` value only for relevant benchmarks.

eerthink committed 4 years ago
Unverified
f8a99b120438d5fae050eca642a24fa0479e4077

ioarena: support comma-separated list for driver options.

eerthink committed 4 years ago

README

The README file for this repository.

ioarena - embedded storage benchmarking

ioarena is an utility designed for evaluating performance of embedded databases.

The goal of this project is to provide a standart and simple in use instrument for benchmarking, so any database developer or user can reference to or repeat obtained results.

Benchmarking methods: set, get, delete, iterate, batch, crud

Sync modes: sync, lazy, no-sync

WAL modes: indef (per engine default), wal-on, wal-off

Supported databases: rocksdb, leveldb, forestdb, upscaledb, lmdb, mdbx, wiredtiger, sophia, sqlite3, iowow, unqlite

New drivers or any kind of enhancements are very welcome!

Usage

IOARENA (embedded storage benchmarking)

usage: ioarena [hDBCpnkvmlrwic]
  -D <database_driver>
     choices: sophia, leveldb, rocksdb, wiredtiger, forestdb, lmdb, mdbx, sqlite3, iowow, dummy, unqlite
  -B <benchmarks>
     choices: set, get, delete, iterate, batch, crud
  -o <driver option>                 (default: none)
  -m <sync_mode>                     (default: lazy)
     choices: sync, lazy, nosync
  -l <wal_mode>                      (default: indef)
     choices: indef, walon, waloff
  -C <name-prefix> generate csv      (default: (null))
  -p <path> for temporaries          (default: ./_ioarena)
  -n <number_of_operations>          (default: 1000000)
  -k <key_size>                      (default: 16)
  -v <value_size>                    (default: 32)
  -c continuous completing mode      (default: no)
  -r <number_of_read_threads>        (default: 0)
     `zero` to use single main/common thread
  -w <number_of_crud/write_threads>  (default: 0)
     `zero` to use single main/common thread
  -i ignore key-not-found error      (default: no)
  -h                                 help

example:
   ioarena -m sync -D sophia -B crud -n 100000000

Build

git clone --recursive https://github.com/pmwkaa/ioarena

cmake is required for building.

To enable a specific database driver, pass -DENABLE_NAME=ON to cmake. If a specified database is not installed in system, it will be build from db/name directory.

mkdir build
cd build
cmake .. -DENABLE_ROCKSDB=ON
make
src/ioarena -h

Authors

Name Contribution
Dmitry Simonenko @pmwkaa Original author.
Leonid Yuriev @erthink Multithreading and isolation from the testcases the interface of a DB drivers cardinally redesigned, it is clear and intelligible now.
Egor Zyryanov @er0p Added support for SQLite, EJDB, Vedis.
Adamansky Anton @adamansky Added support for IOWOW.
Alberto Mardegan @mardy Added support for Upscaledb.