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
Simply use make
to build.
git clone https://github.com/ls4154/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
Clone the source:
git clone git://github.com/wiredtiger/wiredtiger.git
mkdir -p wiredtiger/build
cd wiredtiger/build
Enable built-in compressors and build
cmake -DHAVE_BUILTIN_EXTENSION_LZ4=1 -DHAVE_BUILTIN_EXTENSION_SNAPPY=1 -DHAVE_BUILTIN_EXTENSION_ZLIB=1 -DHAVE_BUILTIN_EXTENSION_ZSTD=1 -DENABLE_STATIC=1 ../.
make -j$(nproc)
sudo make install
Run workload A with wiredtiger:
./ycsb -load -run -db wiredtiger -P workloads/workloada -P wiredtiger/wiredtiger.properties -s
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