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.
 
 
 
 
 
 
Sagar Vemuri 6a6723ee1e Move MergeOperatorPinning tests to be with other merge operator tests 9 years ago
arcanist_util Fix arc setting for Facebook internal tools 9 years ago
buckifier Add buckifier script to github repo 9 years ago
build_tools Rework test running script. 9 years ago
cache Move some files under util/ to separate dirs 9 years ago
cmake/modules CMake: more MinGW fixes 9 years ago
coverage Fix coverage script 11 years ago
db Move MergeOperatorPinning tests to be with other merge operator tests 9 years ago
docs Blog post for releasing 5.2.1 9 years ago
env avoid non-existent O_DIRECT on OpenBSD 9 years ago
examples CMake: more MinGW fixes 9 years ago
hdfs Fix bug in UnScSigned-off-by: xh931076284 <931076284@qq.com> (#1336) 9 years ago
include/rocksdb File level histogram should be printed per CF, not per DB 9 years ago
java Move various string utility functions into string_util 9 years ago
memtable Move memtable related files into memtable directory 9 years ago
monitoring Move various string utility functions into string_util 9 years ago
options Move various string utility functions into string_util 9 years ago
port Move some files under util/ to separate dirs 9 years ago
table Move various string utility functions into string_util 9 years ago
third-party Fix build with MinGW 9 years ago
tools Revert "Report cpu usage using time command" 9 years ago
util Limit maximum memory used in the WriteBatch representation 9 years ago
utilities Fix shared lock upgrades 9 years ago
.clang-format A script that automatically reformat affected lines 12 years ago
.deprecated_arcconfig Deprecate .arcconfig 9 years ago
.gitignore Add buckifier script to github repo 9 years ago
.travis.yml Add Travis job to build examples 9 years ago
AUTHORS Add AUTHORS file. Fix #203 11 years ago
CMakeLists.txt FreeBSD only requires WITH_JEMALLOC, not the rest 9 years ago
CONTRIBUTING.md facebook accounts are not required for CLA signers 11 years ago
DEFAULT_OPTIONS_HISTORY.md Change the default of delayed slowdown value to 16MB/s 9 years ago
DUMP_FORMAT.md First version of rocksdb_dump and rocksdb_undump. 11 years ago
HISTORY.md Revert "delete fallocate with punch_hole" 9 years ago
INSTALL.md Add a notice on gflags installation in INSTALL.md 9 years ago
LANGUAGE-BINDINGS.md Adding Dlang to the list 9 years ago
LICENSE Updated all copyright headers to the new format. 10 years ago
Makefile Move memtable related files into memtable directory 9 years ago
PATENTS Update Patent Grant. 11 years ago
README.md Appveyor badge to show master branch 9 years ago
ROCKSDB_LITE.md Optimistic Transactions 11 years ago
TARGETS Add buckifier script to github repo 9 years ago
USERS.md Update USERS.md add user Pika 9 years ago
Vagrantfile Update Vagrant file (test internal phabricator workflow) 9 years ago
WINDOWS_PORT.md Commit both PR and internal code review changes 10 years ago
appveyor.yml Rework test running script. 9 years ago
src.mk Refactor compaction picker code 9 years ago
thirdparty.inc Introduce XPRESS compresssion on Windows. (#1081) 10 years ago

README.md

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

Build Status 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/