krad d4540654e9 Optimize GetApproximateSizes() to use lesser CPU cycles. 10 years ago
arcanist_util Integrate Jenkins with Phabricator 10 years ago
build_tools Build for CYGWIN 10 years ago
coverage Fix coverage script 10 years ago
db Optimize GetApproximateSizes() to use lesser CPU cycles. 10 years ago
doc Remove seek compaction 11 years ago
examples Fix formatting 10 years ago
hdfs Remove unused parameter in CancelAllBackgroundWork 10 years ago
include Making GetOptions() comment better (#597) 10 years ago
java [RocksJava] Remove deprecated methods 10 years ago
port Build for CYGWIN 10 years ago
table fix typos 10 years ago
third-party Update COMMIT.md 10 years ago
tools Add scripts to run leveldb benchmark 10 years ago
util Fix possible SIGSEGV in CompactRange (github issue #596) 10 years ago
utilities fix typos 10 years ago
.arcconfig Integrate Jenkins with Phabricator 10 years ago
.clang-format A script that automatically reformat affected lines 11 years ago
.gitignore run 'make check's rules (and even subtests) in parallel 10 years ago
.travis.yml Don't preinstall jemalloc in Travis 10 years ago
AUTHORS Add AUTHORS file. Fix #203 10 years ago
CONTRIBUTING.md facebook accounts are not required for CLA signers 11 years ago
HISTORY.md Task 6532943: Rocksdb - SetCapacity() can dynamically change cache capacity if feasible 10 years ago
INSTALL.md Optimize default compile to compilation platform by default 10 years ago
LICENSE Fix copyright year 11 years ago
Makefile One last fix to Makefile 10 years ago
PATENTS Update Patent Grant. 10 years ago
README.md Replaced "built on on earlier work" by "built on earlier work" in README.md 10 years ago
ROCKSDB_LITE.md RocksDBLite 11 years ago
USERS.md Update USERS.md 10 years ago
Vagrantfile RocksDB on FreeBSD support 10 years ago
src.mk Add experimental API MarkForCompaction() 10 years ago

README.md

RocksDB: A Persistent Key-Value Store for Flash and RAM Storage

Build Status

RocksDB is developed and maintained by Facebook Database Engineering Team. It is built on earlier work on LevelDB by Sanjay Ghemawat (sanjay@google.com) and Jeff Dean (jeff@google.com)

This code is a library that forms the core building block for a fast key value server, especially suited for storing data on flash drives. It has a Log-Structured-Merge-Database (LSM) design with flexible tradeoffs between Write-Amplification-Factor (WAF), Read-Amplification-Factor (RAF) and Space-Amplification-Factor (SAF). It has multi-threaded compactions, making it specially suitable for storing multiple terabytes of data in a single database.

Start with example usage here: https://github.com/facebook/rocksdb/tree/master/examples

See the github wiki for more explanation.

The public interface is in include/. Callers should not include or rely on the details of any other header files in this package. Those internal APIs may be changed without warning.

Design discussions are conducted in https://www.facebook.com/groups/rocksdb.dev/