2014-05-07 16:51:30 -07:00
## Compilation
RocksDB's library should be able to compile without any dependency installed,
although we recommend installing some compression libraries (see below).
2014-12-15 11:29:41 +01:00
We do depend on newer gcc/clang with C++11 support.
2014-05-07 16:51:30 -07:00
There are few options when compiling RocksDB:
2013-11-18 11:44:17 -08:00
2014-05-07 16:51:30 -07:00
* [recommended] `make static_lib` will compile librocksdb.a, RocksDB static library.
2013-11-18 11:44:17 -08:00
2014-05-07 16:51:30 -07:00
* `make shared_lib` will compile librocksdb.so, RocksDB shared library.
* `make check` will compile and run all the unit tests
* `make all` will compile our static library, and all our tools and unit tests. Our tools
depend on gflags. You will need to have gflags installed to run `make all` .
2014-12-15 11:29:41 +01:00
* By default the binary we produce is optimized for the platform you're compiling on
(-march=native). If you want to build a portable binary, add 'PORTABLE=1' before
your make commands, like this: `PORTABLE=1 make static_lib`
2014-09-29 17:25:02 -07:00
2014-05-07 16:51:30 -07:00
## Dependencies
* You can link RocksDB with following compression libraries:
2013-11-18 11:44:17 -08:00
- [zlib ](http://www.zlib.net/ ) - a library for data compression.
- [bzip2 ](http://www.bzip.org/ ) - a library for data compression.
- [snappy ](https://code.google.com/p/snappy/ ) - a library for fast
data compression.
2014-05-07 16:51:30 -07:00
* All our tools depend on:
- [gflags ](https://code.google.com/p/gflags/ ) - a library that handles
command line flags processing. You can compile rocksdb library even
if you don't have gflags installed.
2013-11-18 11:44:17 -08:00
## Supported platforms
2014-01-29 08:41:43 -08:00
* **Linux - Ubuntu**
2013-11-18 11:44:17 -08:00
* Upgrade your gcc to version at least 4.7 to get C++11 support.
2014-01-29 08:41:43 -08:00
* Install gflags. First, try: `sudo apt-get install libgflags-dev`
2013-12-02 06:48:23 -08:00
If this doesn't work and you're using Ubuntu, here's a nice tutorial:
2013-11-18 11:44:17 -08:00
(http://askubuntu.com/questions/312173/installing-gflags-12-04)
* Install snappy. This is usually as easy as:
`sudo apt-get install libsnappy-dev` .
* Install zlib. Try: `sudo apt-get install zlib1g-dev` .
* Install bzip2: `sudo apt-get install libbz2-dev` .
2014-01-29 08:41:43 -08:00
* **Linux - CentOS**
* Upgrade your gcc to version at least 4.7 to get C++11 support:
`yum install gcc47-c++`
* Install gflags:
wget https://gflags.googlecode.com/files/gflags-2.0-no-svn-files.tar.gz
tar -xzvf gflags-2.0-no-svn-files.tar.gz
cd gflags-2.0
./configure & & make & & sudo make install
* Install snappy:
wget https://snappy.googlecode.com/files/snappy-1.1.1.tar.gz
tar -xzvf snappy-1.1.1.tar.gz
cd snappy-1.1.1
./configure & & make & & sudo make install
* Install zlib:
sudo yum install zlib
sudo yum install zlib-devel
* Install bzip2:
sudo yum install bzip2
sudo yum install bzip2-devel
2013-11-18 11:44:17 -08:00
* **OS X**:
2013-11-20 14:54:53 -08:00
* Install latest C++ compiler that supports C++ 11:
2013-11-20 14:55:33 -08:00
* Update XCode: run `xcode-select --install` (or install it from XCode App's settting).
* Install via [homebrew ](http://brew.sh/ ).
2013-11-20 14:54:53 -08:00
* If you're first time developer in MacOS, you still need to run: `xcode-select --install` in your command line.
* run `brew tap homebrew/dupes; brew install gcc47 --use-llvm` to install gcc 4.7 (or higher).
2014-12-15 11:29:41 +01:00
* run `brew install rocksdb`
2013-11-18 11:44:17 -08:00
2014-04-04 13:11:44 -07:00
* **iOS**:
2014-10-01 11:15:42 -07:00
* Run: `TARGET_OS=IOS make static_lib` . When building the project which uses rocksdb iOS library, make sure to define two important pre-processing macros: `ROCKSDB_LITE` and `IOS_CROSS_COMPILE` .