You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Adam Retter 3d00271e40 The ability to specify a compaction filter via the Java API 10 years ago
arcanist_util Integrate Jenkins with Phabricator 11 years ago
build_tools Commit both PR and internal code review changes 10 years ago
coverage Fix coverage script 11 years ago
db Style fix in compaction_job.cc 10 years ago
doc Remove seek compaction 12 years ago
examples [API Change] Improve EventListener::OnFlushCompleted interface 11 years ago
hdfs Windows Port from Microsoft 10 years ago
include Better error handling in BackupEngine 10 years ago
java The ability to specify a compaction filter via the Java API 10 years ago
port "make format" against last 10 commits 10 years ago
table Replace std::priority_queue in MergingIterator with custom heap, take 2 10 years ago
third-party "make format" against last 10 commits 10 years ago
tools Make ldb_test not depend on compression 10 years ago
util Replace std::priority_queue in MergingIterator with custom heap, take 2 10 years ago
utilities RemoveEmptyValueCompactionFilter - A compaction filter which removes entries which have an empty value 10 years ago
.arcconfig Integrate Jenkins with Phabricator 11 years ago
.clang-format A script that automatically reformat affected lines 12 years ago
.gitignore Windows Port from Microsoft 10 years ago
.travis.yml Don't preinstall jemalloc in Travis 11 years ago
AUTHORS Add AUTHORS file. Fix #203 11 years ago
CMakeLists.txt Move UniversalCompaction related db-tests to db_universal_compaction_test.cc 10 years ago
CONTRIBUTING.md facebook accounts are not required for CLA signers 11 years ago
DUMP_FORMAT.md First version of rocksdb_dump and rocksdb_undump. 10 years ago
HISTORY.md Better error handling in BackupEngine 10 years ago
INSTALL.md Commit both PR and internal code review changes 10 years ago
LICENSE Fix copyright year 12 years ago
Makefile Replace std::priority_queue in MergingIterator with custom heap, take 2 10 years ago
PATENTS Update Patent Grant. 11 years ago
README.md Replaced "built on on earlier work" by "built on earlier work" in README.md 11 years ago
ROCKSDB_LITE.md Optimistic Transactions 11 years ago
USERS.md Add Yahoo's blog post about Sherpa to USERS.md 11 years ago
Vagrantfile RocksDB on FreeBSD support 11 years ago
WINDOWS_PORT.md Commit both PR and internal code review changes 10 years ago
src.mk The ability to specify a compaction filter via the Java API 10 years ago
thirdparty.inc Conditional use of third-party libraries 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/