GitXplorerGitXplorer
p

ioarena

public
134 stars
24 forks
8 issues

Commits

List of commits on branch master.
Verified
1e7c6c222e55f3a3189e21bd2cd4a1665f4d9ec9

Merge pull request #44 from chuan/clang-fix

ppmwkaa committed 3 years ago
Unverified
9fb8b20d60406faf21e0a72d9f9944764534fbcc

Fix a building error under clang

cchuan committed 3 years ago
Unverified
8ab0e5663e285974579c4d093f934fa908966c5e

mdbx: update submodule to v0.11.2

eerthink committed 3 years ago
Unverified
dfcd2b7184445beca90b5166f9ef79a74566ec09

mdbx: update submodule to v0.10.4

eerthink committed 3 years ago
Unverified
4da2ba84d9ebfcbf78d6333d3944739e7bffe888

mdbx: update submodule to v0.10.3

eerthink committed 3 years ago
Unverified
0594a0fcc4c476ed0f27c27310800eabb18fed2a

Merge branch 'master' of github.com:pmwkaa/ioarena

aadamansky committed 3 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.