forked from zhynwng/hadoop-MLEC
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathinit.sh
executable file
·71 lines (63 loc) · 2.72 KB
/
init.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
# A simple script that install all the necessary environment and build
# hadoop from source
# The script build Hadoop without using docker, and it uses hadoop 3.3.5
#-------------------------------Install packages--------------------------------
# Open JDK 1.
sudo apt-get update
sudo apt-get -y install openjdk-8-jdk
# Maven
sudo apt-get -y install maven
# Native libraries
sudo apt-get -y install build-essential autoconf automake libtool cmake zlib1g-dev pkg-config libssl-dev libsasl2-dev
# GCC 9.3.0
sudo apt-get -y install software-properties-common
sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test
sudo apt-get update
sudo apt-get -y install g++-9 gcc-9
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-9 60 --slave /usr/bin/g++ g++ /usr/bin/g++-9
# CMake 3.19
curl -L https://cmake.org/files/v3.19/cmake-3.19.0.tar.gz > cmake-3.19.0.tar.gz
tar -zxvf cmake-3.19.0.tar.gz && cd cmake-3.19.0
./bootstrap
make -j$(nproc)
sudo make install
# Protocol Buffers 3.7.1 (required to build native code)
curl -L -s -S https://github.com/protocolbuffers/protobuf/releases/download/v3.7.1/protobuf-java-3.7.1.tar.gz -o protobuf-3.7.1.tar.gz
mkdir protobuf-3.7-src
tar xzf protobuf-3.7.1.tar.gz --strip-components 1 -C protobuf-3.7-src && cd protobuf-3.7-src
./configure
make -j$(nproc)
sudo make install
# Boost
curl -L https://sourceforge.net/projects/boost/files/boost/1.72.0/boost_1_72_0.tar.bz2/download > boost_1_72_0.tar.bz2
tar --bzip2 -xf boost_1_72_0.tar.bz2 && cd boost_1_72_0
./bootstrap.sh --prefix=/usr/
./b2 --without-python
sudo ./b2 --without-python install
#------------------------------Build from source--------------------------------
# Build tar
sudo mvn package -Pdist -DskipTests -Dtar -Dmaven.javadoc.skip=true
# Run tests on HDFS
# cd hadoop-hdfs-project && sudo mvn package -Pdist -Dtar -Dmaven.javadoc.skip=true
#-----------------------------Build Node clusters-------------------------------
# Install packages for Node cluster
sudo apt-get install ssh
sudo apt-get install pdsh
# Copy and unpack Hadoop built from source
# cd
# cp hadoop-MLEC/hadoop-dist/target/hadoop-3.3.5.tar.gz ~
# tar xzf hadoop-3.3.5.tar.gz
# rm hadoop-3.3.5.tar.gz
# mv hadoop-3.3.5 hadoop
# echo "JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-amd64" >> hadoop/etc/hadoop/hadoop-env.sh
# Standalone operation
# mkdir input
# cp etc/hadoop/*.xml input
# bin/hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-3.3.5.jar grep input output 'dfs[a-z.]+'
# cat output/*
#-------------------------Set up environment------------------------------------
export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-amd64
ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
chmod 0600 ~/.ssh/authorized_keys
export PDSH_RCMD_TYPE=ssh