forked from seanorama/ambari-bootstrap
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathambari-bootstrap.sh
executable file
·218 lines (183 loc) · 7.06 KB
/
ambari-bootstrap.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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
#!/usr/bin/env bash
set -o errexit
set -o nounset
set -o pipefail
# This script provides an easy install of Ambari
# for RedHat Enterpise Linux 6 & CentOS 6
#
# source at http://github.com/seanorama/ambari-bootstrap
#
# Download and run as root or with sudo. Or alternatively:
# curl -sSL https://raw.githubusercontent.com/seanorama/ambari-bootstrap/master/ambari-bootstrap.sh | sudo -E sh
#
# defaults can be overriden by setting variables in the environment:
# For example:
# export java_provider=oracle
# export install_ambari_server=true
# sh ambari-bootstrap.sh
install_ambari_agent="${install_ambari_agent:-true}"
install_ambari_server="${install_ambari_server:-false}"
iptables_disable="${iptables_disable:-true}"
java_provider="${java_provider:-open}" # accepts: open, oracle
java_version="${java_version:-8}"
ambari_server="${ambari_server:-localhost}"
ambari_version="${ambari_version:-2.5.0.3}"
ambari_version_major="${ambari_version_major:-$(echo ${ambari_version} | cut -c 1).x}"
ambari_server_custom_script="${ambari_server_custom_script:-/bin/true}"
ambari_repo_baseurl="${ambari_repo_baseurl:-http://public-repo-1.hortonworks.com/ambari}"
##ambari_repo= ## if using a local repo. Otherwise the repo path is determined automatically in a line below.
curl="curl -ksSL"
command_exists() {
command -v "$@" > /dev/null 2>&1
}
if [ ! "$(hostname -f)" ]; then
printf >&2 'Error: "hostname -f" failed to report an FQDN.\n'
printf >&2 'The system must report a FQDN in order to use Ambari\n'
exit 1
fi
if [ "$(id -ru)" != 0 ]; then
printf >&2 'Error: this installer needs the ability to run commands as root.\n'
printf >&2 'Install as root or with sudo\n'
exit 1
fi
case "$(uname -m)" in
*64)
;;
*)
printf >&2 'Error: you are not using a 64bit platform.\n'
printf >&2 'This installer requires a 64bit platforms.\n'
exit 1
;;
esac
## basic platform detection
lsb_dist=''
if [ -r /etc/centos-release ]; then
lsb_dist="centos"
lsb_dist_release=$(awk '{print $(NF-1)}' /etc/centos-release | cut -d "." -f1)
elif [ -r /etc/redhat-release ]; then
lsb_dist="centos"
lsb_dist_release=$(awk '{print $(NF-1)}' /etc/redhat-release | cut -d "." -f1)
elif [ -r /etc/os-release ] && [ $(awk '$1=="ID" {gsub("\"", ""); print $2}' FS='=' /etc/os-release) == "amzn" ]; then
lsb_dist="centos"
lsb_dist_release=6
fi
lsb_dist="$(echo "${lsb_dist}" | tr '[:upper:]' '[:lower:]')"
ambari_repo="${ambari_repo:-${ambari_repo_baseurl}/${lsb_dist}${lsb_dist_release}/${ambari_version_major}/updates/${ambari_version}/ambari.repo}"
if command_exists ambari-agent || command_exists ambari-server; then
printf >&2 'Warning: "ambari-agent" or "ambari-server" command appears to already exist.\n'
printf >&2 'Please ensure that you do not already have ambari-agent installed.\n'
printf >&2 'You may press Ctrl+C now to abort this process and rectify this situation.\n'
( set -x; sleep 20 )
fi
my_disable_thp() {
( cat > /usr/local/sbin/ambari-thp-disable.sh <<-'EOF'
#!/usr/bin/env bash
# disable transparent huge pages: for Hadoop
thp_disable=true
if [ "${thp_disable}" = true ]; then
for path in redhat_transparent_hugepage transparent_hugepage; do
for file in enabled defrag; do
if test -f /sys/kernel/mm/${path}/${file}; then
echo never > /sys/kernel/mm/${path}/${file}
fi
done
done
fi
exit 0
EOF
)
chmod +x /usr/local/sbin/ambari-thp-disable.sh
sh /usr/local/sbin/ambari-thp-disable.sh
printf '\nsh /usr/local/sbin/ambari-thp-disable.sh || /bin/true\n\n' >> /etc/rc.local
}
my_disable_ipv6() {
mkdir -p /etc/sysctl.d
( cat > /etc/sysctl.d/99-hadoop-ipv6.conf <<-'EOF'
## Disabled ipv6
## Provided by Ambari Bootstrap
net.ipv6.conf.all.disable_ipv6 = 1
net.ipv6.conf.default.disable_ipv6 = 1
net.ipv6.conf.lo.disable_ipv6 = 1
EOF
)
sysctl -e -p /etc/sysctl.d/99-hadoop-ipv6.conf
}
case "${lsb_dist}" in
centos|redhat)
case "${lsb_dist_release}" in
6|7)
(
set +o errexit
printf "## Info: Disabling IPv6\n"
my_disable_ipv6
printf "## Info: Installing base packages\n"
yum install -y -q curl ntp openssl python zlib wget unzip openssh-clients
printf "## Info: Fixing sudo to not requiretty. This is the default in newer distributions\n"
printf 'Defaults !requiretty\n' > /etc/sudoers.d/888-dont-requiretty
setenforce 0 || true
sed -i 's/\(^[^#]*\)SELINUX=enforcing/\1SELINUX=disabled/' /etc/selinux/config
sed -i 's/\(^[^#]*\)SELINUX=permissive/\1SELINUX=disabled/' /etc/selinux/config
printf "## Info: Disabling Transparent Huge Pages\n"
my_disable_thp
if [ "${iptables_disable}" = true ]; then
printf "## Info: Disabling iptables\n"
chkconfig iptables off || true
service iptables stop || true
chkconfig ip6tables off || true
service ip6tables stop || true
fi
printf "## Syncing time via ntpd\n"
ntpd -qg || true
chkconfig ntpd on || true
service ntpd restart || true
)
if [ "${java_provider}" != 'oracle' ]; then
printf "## installing java\n"
yum install -q -y java-1.${java_version}.0-openjdk-devel
mkdir -p /usr/java
ln -sf /etc/alternatives/java_sdk /usr/java/default
#update-alternatives --set java /usr/lib/jvm/jre-1.${java_version}.0-openjdk/bin/java
JAVA_HOME='/usr/java/default'
fi
printf "## fetch ambari repo\n"
${curl} -o /etc/yum.repos.d/ambari.repo \
"${ambari_repo}"
if [ "${install_ambari_agent}" = true ]; then
printf "## installing ambari-agent\n"
yum install -q -y ambari-agent
sed -i.orig -r 's/^[[:space:]]*hostname=.*/hostname='"${ambari_server}"'/' \
/etc/ambari-agent/conf/ambari-agent.ini
chkconfig ambari-agent on
ambari-agent start
fi
if [ "${install_ambari_server}" = true ]; then
printf "## install ambari-server\n"
yum install -q -y ambari-server
if [ "${java_provider}" = 'oracle' ]; then
ambari-server setup -s
else
ambari-server setup -j "${JAVA_HOME}" -s
fi
sh -c "${ambari_server_custom_script}"
chkconfig ambari-server on
if ! nohup sh -c "ambari-server start 2>&1 > /dev/null"; then
printf 'Ambari Server failed to start\n' >&2
fi
fi
printf "## Success! All done.\n"
exit 0
;;
esac
;;
esac
cat >&2 <<'EOF'
Your platform is not currently supported by this script or was not
easily detectable.
The script currently supports:
Red Hat Enterprise Linux 6 & 7
CentOS 6 & 7
Please visit the following URL for more detailed installation
instructions:
https://docs.hortonworks.com/
EOF
exit 1