-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathstorm_install.sh
executable file
·269 lines (224 loc) · 5.93 KB
/
storm_install.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
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
#!/bin/bash
pp() {
echo -e "\e[00;32m"$1"\e[00m"
}
HOST=`hostname`
#########################################
# Clean up old installation.
#########################################
cleanup() {
pp "Cleaning up previous installation..."
rm -rf $BASEDIR
mkdir $BASEDIR
echo "#!/bin/bash" > $START_SH
chmod +x $START_SH
echo "#!/bin/bash" > $STOP_SH
chmod +x $STOP_SH
}
#########################################
# System dependencies.
#########################################
deps() {
pp "Checking system dependencies..."
echo
sudo apt-get install screen daemontools uuid-dev git libtool build-essential openjdk-6-jdk unzip
echo
}
#########################################
# ZooKeeper.
#########################################
zookeeper() {
if [ "$HOST" != "$NIMBUS" ]
then
pp "Skipping ZooKeeper installation on all hosts but nimbus!"
return
fi
ZK_VERSION="3.3.6"
ZK_DIR=$BASEDIR"/zookeeper"
ZK_CONFIGFILE="zoo.conf"
ZK_CONF=$ZK_DIR"/"$ZK_CONFIGFILE
ZK_RUN=$ZK_DIR"/run"
ZK_PURGE=$ZK_DIR"/purge.sh"
ZK_DATADIR=$ZK_DIR"/data"
ZK_TARBALL_URL="http://apache.openmirror.de/zookeeper/zookeeper-"$ZK_VERSION"/zookeeper-"$ZK_VERSION".tar.gz"
ZK_TARBALL=$ZK_DIR/"zookeeper.tar.gz"
ZK_INSTALLDIR=$ZK_DIR/"zookeeper-"$ZK_VERSION
pp "Installing ZooKeeper "$ZK_VERSION" on nimbus host '"$HOST"'..."
mkdir $ZK_DIR &>/dev/null
mkdir $ZK_DATADIR &>/dev/null
pp "Downloading ZooKeeper..."
wget $ZK_TARBALL_URL -q -O $ZK_TARBALL
tar xzf $ZK_TARBALL -C $ZK_DIR
rm $ZK_TARBALL
pp "Configuring ZooKeeper..."
# Cluster config.
cat << EOF > $ZK_CONF
tickTime=2000
dataDir=$ZK_DATADIR
clientPort=2181
initLimit=5
syncLimit=2
server.1=$NIMBUS:2888:3888
EOF
# This host's id.
echo "1" > $ZK_DATADIR/myid
# Run script.
ZK_CP=$ZK_INSTALLDIR/zookeeper-$ZK_VERSION.jar:$ZK_INSTALLDIR/lib/log4j-1.2.15.jar:$ZK_INSTALLDIR/conf
cat << EOF > $ZK_RUN
#!/bin/bash
_JAVA_OPTIONS="-Xmx1024M -Xms1024M"
java -cp $ZK_CP org.apache.zookeeper.server.quorum.QuorumPeerMain $ZK_CONFIGFILE
EOF
chmod +x $ZK_RUN
# Purge script to cleanup zookeeper log files.
cat << EOF > $ZK_PURGE
mkdir $ZK_DIR/snap
java -cp $ZK_CP org.apache.zookeeper.server.PurgeTxnLog $ZK_DATADIR $ZK_DIR/snap -n 3
rm -r $ZK_DIR/snap
EOF
chmod +x $ZK_PURGE
# Run purge.sh via cron job.
echo "@hourly $ZK_PURGE" | crontab -
# Update global start/stop scripts.
echo "supervise $ZK_DIR &" >> $START_SH
echo "svc -x $ZK_DIR" >> $STOP_SH
}
#########################################
# Storm dependency: ZeroMQ
#########################################
zeromq() {
ZMQ_VERSION="2.1.7"
ZMQ_DIR=$BASEDIR"/zeromq"
ZMQ_TARBALL_URL="http://download.zeromq.org/zeromq-"$ZMQ_VERSION".tar.gz"
ZMQ_TARBALL=$ZMQ_DIR"/zeromq.tar.gz"
pp "Installing ZeroMQ "$ZMQ_VERSION" (storm dependency)..."
mkdir $ZMQ_DIR
pp "Downloading ZeroMQ..."
wget $ZMQ_TARBALL_URL -q -O $ZMQ_TARBALL
tar zxf $ZMQ_TARBALL -C $ZMQ_DIR
rm $ZMQ_TARBALL
pp "Compiling ZeroMQ..."
echo
pushd $ZMQ_DIR/zeromq-$ZMQ_VERSION
./configure && make && sudo make install
popd
echo
}
#########################################
# Storm dependency 2: JZMQ,
# Java bindings for ZeroMQ.
#
# This is where things get tricky.
# Despite the warning on nathanmarz' page,
# we use mainline git here, as it compiles
# with the latest autoconf and libtool on
# Ubuntu 12.04.
#########################################
jzmq() {
JZMQ_DIR=$BASEDIR"/jzmq"
JZMQ_REPO="https://github.com/zeromq/jzmq.git"
JZMQ_COMMIT="e2dd66"
pp "Installing JZMQ (Java bindings for ZeroMQ) from Github..."
git clone -q $JZMQ_REPO $JZMQ_DIR
pp "Compiling JZMQ..."
echo
pushd $JZMQ_DIR
git checkout $JZMQ_COMMIT
./autogen.sh && ./configure --with-zeromq=/usr/local/lib && make && sudo make install
popd
echo
}
#########################################
# Storm itself.
#########################################
storm() {
STORM_VERSION="0.8.2"
STORM_DIR=$BASEDIR"/storm"
STORM_ZIP_URL="https://dl.dropbox.com/u/133901206/storm-"$STORM_VERSION".zip"
STORM_ZIP=$STORM_DIR"/storm.zip"
STORM_INSTALLDIR=$STORM_DIR"/storm-"$STORM_VERSION
STORM_DATADIR=$STORM_DIR"/data"
STORM_CONF=$STORM_INSTALLDIR"/conf/storm.yaml"
STORM_RUN=$STORM_DIR"/run"
pp "Installing Storm "$STORM_VERSION"..."
mkdir $STORM_DIR >/dev/null
mkdir $STORM_DATADIR >/dev/null
pp "Downloading Storm..."
wget $STORM_ZIP_URL -q -O $STORM_ZIP
unzip -qq $STORM_ZIP -d $STORM_DIR
rm $STORM_ZIP
pp "Configuring Storm..."
echo "storm.local.dir: \""$STORM_DATADIR"\"" > $STORM_CONF
echo "storm.zookeeper.servers:" >> $STORM_CONF
echo " - \""$NIMBUS"\"" >> $STORM_CONF
if [ "$HOST" != "$NIMBUS" ]
then
echo "nimbus.host: \""$NIMBUS"\"" >> $STORM_CONF
fi
# Supervisor directories/scripts + global start/stop scripts.
# Note: If we're NIMBUS, we run the 'nimbis' action instead.
if [ "$HOST" = "$NIMBUS" ]; then STORM_ACTION="nimbus"; else STORM_ACTION="supervisor"; fi
cat << EOF > $STORM_RUN
#!/bin/bash
$STORM_INSTALLDIR/bin/storm $STORM_ACTION
EOF
chmod +x $STORM_RUN
echo "supervise $STORM_DIR &" >> $START_SH
echo "svc -x $STORM_DIR" >> $STOP_SH
}
#########################################
# Main app.
#########################################
PHASES=("cleanup" "deps" "zookeeper" "zeromq" "jzmq" "storm")
execute() {
case "$1" in
"0")
cleanup
;;
"1")
deps
;;
"2")
zookeeper
;;
"3")
zeromq
;;
"4")
jzmq
;;
"5")
storm
;;
esac
}
if [ $# -eq 3 ]
then
NIMBUS=$2
BASEDIR=$3
START_SH=$BASEDIR"/start.sh"
STOP_SH=$BASEDIR"/stop.sh"
if [ "$1" = "all" ]
then
# Run everything.
for ((p=0;p<${#PHASES[@]};p++))
do
execute $p
done
pp "Installation complete."
pp "Be sure to carefully read the log."
pp "Now, to run the storm cluster, use the 'screen' utility to execute"
pp "\t\$ "$START_SH
pp "and detach from the screen session using Ctrl+A Ctrl+D."
else
execute $1
pp "Phase installation complete."
fi
else
echo "Usage: ./install_storm <number_of_phase>/all <nimbus> <installdir>"
echo "Phases:"
for ((i=0;i<${#PHASES[@]};i++))
do
echo -e "\t"$i": "${PHASES[$i]}
done
fi