nkaush / YCSB-cpp

[Fork] YCSB written in C++ for LevelDB, RocksDB and LMDB.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

YCSB-cpp

Yahoo! Cloud Serving Benchmark(YCSB) written in C++. This is a fork of YCSB-C with some additions

  • Tail latency report using HdrHistogram_c
  • Small changes to make it behave more like the original YCSB
  • Supported Databases: LevelDB, RocksDB, LMDB, WiredTiger

For detailed instructions to run artifact evaluation, see README-ae.md.

Build YCSB-cpp

Build with Makefile on POSIX

Simply use make to build.

git clone https://github.com/dassl-uiuc/YCSB-cpp.git
cd YCSB-cpp
git submodule update --init
make

Databases to bind must be specified as build options. You may also need to add additional link flags (e.g., -lsnappy).

To bind LevelDB:

make BIND_LEVELDB=1

To build with additional libraries and include directories:

make BIND_LEVELDB=1 EXTRA_CXXFLAGS=-I/example/leveldb/include \
                    EXTRA_LDFLAGS="-L/example/leveldb/build -lsnappy"

Or modify config section in Makefile.

RocksDB build example:

EXTRA_CXXFLAGS ?= -I/example/rocksdb/include
EXTRA_LDFLAGS ?= -L/example/rocksdb -ldl -lz -lsnappy -lzstd -lbz2 -llz4

BIND_ROCKSDB ?= 1

Build with CMake on POSIX

git submodule update --init
mkdir build
cd build
cmake -DBIND_ROCKSDB=1 -DBIND_WIREDTIGER=1 -DBIND_LMDB=1 -DBIND_LEVELDB=1 -DWITH_SNAPPY=1 -DWITH_LZ4=1 -DWITH_ZSTD=1 ..
make

Build with CMake+vcpkg on Windows

see BUILD_ON_WINDOWS

Running

Load data with leveldb:

./ycsb -load -db leveldb -P workloads/workloada -P leveldb/leveldb.properties -s

Run workload A with leveldb:

./ycsb -run -db leveldb -P workloads/workloada -P leveldb/leveldb.properties -s

Load and run workload B with rocksdb:

./ycsb -load -run -db rocksdb -P workloads/workloadb -P rocksdb/rocksdb.properties -s

Pass additional properties:

./ycsb -load -db leveldb -P workloads/workloadb -P rocksdb/rocksdb.properties \
    -p threadcount=4 -p recordcount=10000000 -p leveldb.cache_size=134217728 -s

About

[Fork] YCSB written in C++ for LevelDB, RocksDB and LMDB.

License:Apache License 2.0


Languages

Language:C++ 79.4%Language:Shell 10.9%Language:Python 6.4%Language:CMake 2.0%Language:Makefile 1.3%