-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpost-deployment-steps.sh
140 lines (126 loc) · 4.99 KB
/
post-deployment-steps.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
#!/bin/bash
#
# Do all the post-deployment steps on the Accumulo cluster
#
cd ~
rm --force ./post-deployment-steps.log
exec > >(tee --append ./post-deployment-steps.log)
exec 2>&1
date
echo "Read the options"
TEMP=`getopt -o a:p:t:s:g:n:u:d --long spappid:,sppassword:,sptenantid:,subscription:,resource-group:,nameserviceid:,admin-username:,data-size: -- "$@"`
eval set -- "$TEMP"
echo "Extract options and their arguments into variables"
while true ; do
case "$1" in
-a|--spappid)
spappid=$2 ; shift 2;;
-p|--sppassword)
sppassword=$2 ; shift 2;;
-t|--sptenantid)
sptenantid=$2 ; shift 2;;
-s|--subscription)
subscription=$2 ; shift 2;;
-g|--resource-group)
resourcegroup=$2 ; shift 2;;
-n|--nameserviceid)
nameserviceid=$2 ; shift 2;;
-u|--admin-username)
adminusername=$2 ; shift 2;;
-d|--data-size)
dataSize=$2 ; shift 2;;
--) shift ; break ;;
*) echo "ERROR: Unable to get variables from arguments" ; exit 1 ;;
esac
done
if [ -z "$spappid" ]
then
echo "Missing required argument: -a | spappid"
exit 1
fi
if [ -z "$sppassword" ]
then
echo "Missing required argument: -p | sppassword"
exit 1
fi
if [ -z "$sptenantid" ]
then
echo "Missing required argument: -t | sptenantid"
exit 1
fi
if [ -z "$subscription" ]
then
echo "Missing required argument: -s | subscription"
exit 1
fi
if [ -z "$resourcegroup" ]
then
echo "Missing required argument: -g | resource-group"
exit 1
fi
if [ -z "$nameserviceid" ]
then
echo "Missing required argument: -n | nameserviceid"
exit 1
fi
if [ -z "$adminusername" ]
then
echo "Missing required argument: -u | admin-username"
exit 1
fi
if [ -z "$dataSize" ]
then
echo "Missing required argument: -d | data-size"
exit 1
fi
echo "Update yarn configs for all nodes"
# https://stackoverflow.com/questions/7619438/bash-read-a-file-line-by-line-and-process-each-segment-as-parameters-to-other-p#7619467
while read hostname ipaddress
do
# https://stackoverflow.com/questions/6351022/executing-ssh-command-in-a-bash-shell-script-within-a-loop
# https://superuser.com/questions/125324/how-can-i-avoid-sshs-host-verification-for-known-hosts
echo "set properties in "${hostname}
ssh -T -o "StrictHostKeyChecking no" ${adminusername}@${hostname} << 'EOF'
echo "set yarn.nodemanager.resource.memory-mb"
sed -i '/yarn.nodemanager.resource.memory-mb/{n; s/<value>.*<\/value>/<value>32768<\/value>/}' ~/install/hadoop-3.2.0/etc/hadoop/yarn-site.xml
echo "set yarn.scheduler.maximum-allocation-mb"
if ! grep -q yarn.scheduler.maximum-allocation-mb ~/install/hadoop-3.2.0/etc/hadoop/yarn-site.xml; then
lineIndex=`sed -n '/yarn.nodemanager.resource.memory-mb/=' ~/install/hadoop-3.2.0/etc/hadoop/yarn-site.xml`
lineIndex=$(($lineIndex + 2))
elem="<property>\n\t\t<name>yarn.scheduler.maximum-allocation-mb</name>\n\t\t<value>32768</value>\n\t</property>"
elem=$(echo $elem | sed 's/\//\\\//g')
sed -i "${lineIndex}a\\\t${elem}" ~/install/hadoop-3.2.0/etc/hadoop/yarn-site.xml
fi
echo "set spark.yarn.am.cores"
if ! grep -q spark.yarn.am.cores ~/install/spark-2.4.3-bin-without-hadoop/conf/spark-defaults.conf; then
echo "spark.yarn.am.cores 4" >> ~/install/spark-2.4.3-bin-without-hadoop/conf/spark-defaults.conf
fi
echo "set spark.yarn.am.memory"
if ! grep -q spark.yarn.am.memory ~/install/spark-2.4.3-bin-without-hadoop/conf/spark-defaults.conf; then
echo "spark.yarn.am.memory 12g" >> ~/install/spark-2.4.3-bin-without-hadoop/conf/spark-defaults.conf
fi
EOF
done < ~/fluo-muchos/conf/hosts/${nameserviceid}
echo "login Azure CLI using service principal"
az login --service-principal --username ${spappid} --password ${sppassword} --tenant ${sptenantid}
echo "set subscription"
az account set --subscription ${subscription}
echo "set default resource group"
az configure --defaults group=${resourcegroup}
echo "Restart scale set"
az vmss restart --resource-group ${resourcegroup} --name ${nameserviceid}
echo "start zookeepers"
head -3 ~/fluo-muchos/conf/hosts/${nameserviceid} |
while read hostname ipaddress
do
echo "start zookeeper - hostname: ${hostname}, ipaddress: ${ipaddress}"
ssh -n -o "StrictHostKeyChecking no" ${adminusername}@${hostname} "~/install/zookeeper-3.4.14/bin/zkServer.sh start"
done
read hostname ipaddress < ~/fluo-muchos/conf/hosts/${nameserviceid}
echo "master - hostname: ${hostname}, ipaddress: ${ipaddress}"
echo "start dfs"
ssh -o "StrictHostKeyChecking no" ${adminusername}@${hostname} "~/install/hadoop-3.2.0/sbin/start-dfs.sh"
echo "start yarn"
ssh -o "StrictHostKeyChecking no" ${adminusername}@${hostname} "~/install/hadoop-3.2.0/sbin/start-yarn.sh"
echo "start accumulo"
ssh -o "StrictHostKeyChecking no" ${adminusername}@${hostname} "~/install/accumulo-2.0.0/bin/accumulo-cluster start"