A Low-Latency Multi-Version Key-Value Store Using B-Tree on an FPGA-CPU Platform.

Yuchen Ren,Jinyu Xie,Yunhui Qiu,Hankun Lv,Wenbo Yin,Lingli Wang,Bowei Yu,Hua Chen,Xianjun He,Zhijian Liao,Xiaozhong Shi
DOI: https://doi.org/10.1109/fpl.2019.00058
2019-01-01
Abstract:In recent years, a variety of methods for low-latency key-value store (KVS), such as remote direct memory access (RDMA), have been proposed. However, a majority of KVS systems do not support to access and query data stored in multiple versions, making them inapplicable to application scenarios like snapshot. In this paper, we present a low-latency multi-version in-memory KVS on an FPGA-CPU platform. In order to reduce latency, we store all keys into a hash table using cuckoo hashing on an FPGA board and organize each group of version-value pairs that are corresponded with the identical key into a B-tree in the host memory. The proposed architecture can perform put, get, delete, CAS, getPredecessor and range query operations within a B-tree. Every operation except range query can be completed bypassing the host CPU. The experimental results show that the average latency of get operation within a B-tree of 5 levels is less than 8?s which is at least 9x faster than other implementations with the help of CPU.
What problem does this paper attempt to address?