Heron can currently be built on the following Linux platforms:
To build Heron on a fresh Ubuntu 14.04 installation:
$ sudo apt-get update -y $ sudo apt-get upgrade -y
$ sudo apt-get install git build-essential automake cmake libtool-bin zip \ libunwind-setjmp0-dev zlib1g-dev unzip pkg-config python-setuptools -y
export CC=/usr/bin/gcc export CCX=/usr/bin/g++
$ sudo add-apt-repository ppa:webupd8team/java $ sudo apt-get update -y $ sudo apt-get install oracle-java8-installer -y $ export JAVA_HOME="/usr/lib/jvm/java-8-oracle"
wget -O /tmp/bazel.sh https://github.com/bazelbuild/bazel/releases/download/0.23.2/bazel-0.23.2-installer-linux-x86_64.sh chmod +x /tmp/bazel.sh /tmp/bazel.sh --user
Make sure to download the appropriate version of Bazel (currently {{% bazelVersion %}}).
$ sudo apt-get install python-dev python-pip
PATH
$ export PATH="$PATH:$HOME/bin"
$ git clone https://github.com/apache/incubator-heron.git && cd heron
$ ./bazel_configure.py
$ bazel build --config=ubuntu heron/...
$ bazel build --config=ubuntu scripts/packages:binpkgs $ bazel build --config=ubuntu scripts/packages:tarpkgs
This will install Heron packages in the bazel-bin/scripts/packages/
directory.
If you encounter errors with libunwind, libtool, or gperftools, we recommend installing them manually.
$ wget http://ftpmirror.gnu.org/libtool/libtool-2.4.6.tar.gz $ tar -xvf libtool-2.4.6.tar.gz $ cd libtool-2.4.6 $ ./configure $ make $ sudo make install
$ wget http://download.savannah.gnu.org/releases/libunwind/libunwind-1.1.tar.gz $ tar -xvf libunwind-1.1.tar.gz $ cd libunwind-1.1 $ ./configure $ make $ sudo make install
$ wget https://github.com/gperftools/gperftools/releases/download/gperftools-2.5/gperftools-2.5.tar.gz $ tar -xvf gperftools-2.5.tar.gz $ cd gperftools-2.5 $ ./configure $ make $ sudo make install
To build Heron on a fresh CentOS 7 installation:
$ sudo yum install gcc gcc-c++ kernel-devel wget unzip zlib-devel zip git automake cmake patch libtool -y
$ wget http://download.savannah.gnu.org/releases/libunwind/libunwind-1.1.tar.gz $ tar xvf libunwind-1.1.tar.gz $ cd libunwind-1.1 $ ./configure $ make $ sudo make install
$ export CC=/usr/bin/gcc $ export CCX=/usr/bin/g++
$ cd /opt/ $ sudo wget --no-cookies --no-check-certificate \ --header "Cookie: gpw_e24=http%3A%2F%2Fwww.oracle.com%2F; oraclelicense=accept-securebackup-cookie" \ "http://download.oracle.com/otn-pub/java/jdk/8u91-b14/jdk-8u91-linux-x64.tar.gz" $ sudo tar xzf jdk-8u91-linux-x64.tar.gz
Use alternatives
to configure the Java version:
$ sudo cd /opt/jdk1.8.0_91/ $ sudo alternatives --install /usr/bin/java java /opt/jdk1.8.0_91/bin/java 2 $ sudo alternatives --config java
Set the javac
and jar
commands:
$ sudo alternatives --install /usr/bin/jar jar /opt/jdk1.8.0_91/bin/jar 2 $ sudo alternatives --install /usr/bin/javac javac /opt/jdk1.8.0_91/bin/javac 2 $ sudo alternatives --set jar /opt/jdk1.8.0_91/bin/jar $ sudo alternatives --set javac /opt/jdk1.8.0_91/bin/javac
Export Java-related environment variables:
export JAVA_HOME=/opt/jdk1.8.0_91 export JRE_HOME=/opt/jdk1.8.0_91/jre export PATH=$PATH:/opt/jdk1.8.0_91/bin:/opt/jdk1.8.0_91/jre/bin
wget -O /tmp/bazel.sh https://github.com/bazelbuild/bazel/releases/download/0.23.2/bazel-0.23.2-installer-linux-x86_64.sh chmod +x /tmp/bazel.sh /tmp/bazel.sh --user
Make sure to download the appropriate version of Bazel (currently {{% bazelVersion %}}).
$ git clone https://github.com/apache/incubator-heron.git && cd heron $ ./bazel_configure.py $ bazel build --config=centos heron/...
$ bazel build --config=centos scripts/packages:binpkgs $ bazel build --config=centos scripts/packages:tarpkgs
This will install Heron packages in the bazel-bin/scripts/packages/
directory.