Skip to content

SZ-NPE/HashKV

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

HashKV

Enabling Efficient Updates in Key-value Storage via Hashing

Overview

The prototype is written in C++ and uses 3rd parity libraries, including

Minimal Requirements

Minimal requirement to test the prototype:

  • Ubuntu 14.04 LTS (Server)
  • 1GB RAM

Installation

  1. On Ubuntu 14.04 LTS (Server), install
    • C++ compiler: g++ (version 4.8.4 or above)
    • Boost library: libboost-system-dev, libboost-filesystem-dev, libboost-thread-dev
    • Snappy: libsnappy-dev
    • CMake (required to compile HdrHistogram_c): cmake
    • Zlib (required to compile HdrHistogram_c): zlib1g-dev
$ sudo apt-get update
$ sudo apt-get install g++ libboost-system-dev libboost-filesystem-dev libboost-thread-dev libsnappy-dev cmake zlib1g-dev
  1. Download and extract the source code tarball (./hashkv-*.tar.gz)
$ tar zxf hashkv-*.tar.gz
  1. Setup the environment variable for HashKV as the root directory of folder hashkv
$ cd hashkv
$ export HASHKV_HOME=$(pwd)
  1. Compile HdrHistogram_c (libhdr_histogram.so) under lib/HdrHistogram_c-0.9.4,
$ cd ${HASHKV_HOME}/lib/HdrHistogram_c-0.9.4
$ cmake .
$ make
  1. Compile LevelDB (libleveldb.so) under lib/leveldb,
$ cd ${HASHKV_HOME}/lib/leveldb
$ make

Testing the Prototype

  1. Compile the prototype and the test program.
$ cd ${HASHKV_HOME}
$ make

The test program is generated under bin/ after compilation, named hashkv_test.

  1. Before running, add path to shared libraries under lib/leveldb/out-shared and lib/HdrHistogram_c-0.9.4/src:
$ export LD_LIBRARY_PATH="$HASHKV_HOME/lib/leveldb/out-shared:$HASHKV_HOME/lib/HdrHistogram_c-0.9.4/src:$LD_LIBRARY_PATH"
  1. Then, switch to folder bin/
$ cd ${HASHKV_HOME}/bin
  1. Create the folder for key storage (LSM-tree), which is named leveldb by default
$ mkdir leveldb
  1. Create the folder for value storage
$ mkdir data_dir
  1. Clean the LSM-tree and the value storage folders before run
$ rm -f data_dir/* leveldb/*
  1. Choose and copy one of the example configuration files [db_sample_config.ini] corresponding to different designs
  • HashKV: hashkv_sample_config.ini
  • vLog: vlog_sample_config.ini
  • LevelDB: leveldb_sample_config.ini
$ cp [db_sample_config.ini] config.ini
  1. Run the test program of the prototype under the chosen design
$ ./hashkv_test data_dir 100000

You can repeat steps 6-8 to try other designs.

Note that since the data layout differs between designs, the LSM-tree and the value store folders must be cleared when one switches to another design.

Publications

See our papers for greater design details of HashKV:

Releases

No releases published

Packages

No packages published

Languages

  • C++ 81.3%
  • C 12.7%
  • HTML 3.6%
  • Makefile 1.5%
  • Shell 0.5%
  • CMake 0.3%
  • CSS 0.1%