96a13b4f4b
Summary: Problem: During RocksJava performance testing we found that the rocksdb jni library is not built with jemalloc; instead it was getting built with the default glibc malloc. We saw quite a bit of memory bloat due to this. Addressed this by installing jemalloc-devel package in the vm that we use to build release jars. Closes https://github.com/facebook/rocksdb/pull/2916 Differential Revision: D5887018 Pulled By: sagar0 fbshipit-source-id: ace0b5d60234b3a30dcd5d39633e7827a5982a50
32 lines
1.2 KiB
Bash
Executable File
32 lines
1.2 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
set -e
|
|
|
|
# remove fixed relesever variable present in the hanscode boxes
|
|
sudo rm -f /etc/yum/vars/releasever
|
|
|
|
# enable EPEL
|
|
sudo yum -y install epel-release
|
|
|
|
# install all required packages for rocksdb that are available through yum
|
|
sudo yum -y install openssl java-1.7.0-openjdk-devel zlib-devel bzip2-devel lz4-devel snappy-devel libzstd-devel jemalloc-devel
|
|
|
|
# install gcc/g++ 4.8.2 from tru/devtools-2
|
|
sudo wget -O /etc/yum.repos.d/devtools-2.repo https://people.centos.org/tru/devtools-2/devtools-2.repo
|
|
sudo yum -y install devtoolset-2-binutils devtoolset-2-gcc devtoolset-2-gcc-c++
|
|
|
|
# install gflags
|
|
wget https://github.com/gflags/gflags/archive/v2.0.tar.gz -O gflags-2.0.tar.gz
|
|
tar xvfz gflags-2.0.tar.gz; cd gflags-2.0; scl enable devtoolset-2 ./configure; scl enable devtoolset-2 make; sudo make install
|
|
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib
|
|
|
|
# set java home so we can build rocksdb jars
|
|
export JAVA_HOME=/usr/lib/jvm/java-1.7.0
|
|
|
|
# build rocksdb
|
|
cd /rocksdb
|
|
scl enable devtoolset-2 'make jclean clean'
|
|
scl enable devtoolset-2 'PORTABLE=1 make rocksdbjavastatic'
|
|
cp /rocksdb/java/target/librocksdbjni-* /rocksdb-build
|
|
cp /rocksdb/java/target/rocksdbjni-* /rocksdb-build
|