forked from ably77/dcos-kubernetes-training
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstructor_automated.sh
executable file
·56 lines (42 loc) · 2.02 KB
/
instructor_automated.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
## CHANGE THIS EVERY TIME!!!
export APPNAME=training
export PUBLICIP=54.149.137.143
export CLUSTER=k8straining-clustertest
export REGION=us-west-2
clusters=40
#### Remove all DC/OS Clusters
rm -rf ~/.dcos/clusters
#### SETUP MASTER URL VARIABLE
# NOTE: elb url is not used in this script (yet) TODO
if [[ $1 == "" ]]
then
echo
echo " A master node's URL was not entered. Aborting."
echo
exit 1
fi
# For the master change http to https so kubectl setup doesn't break
MASTER_URL=$(echo $1 | sed 's/http/https/')
#### SETUP CLI
./scripts/setup_cli.sh $MASTER_URL
loadbalancer=ext-$CLUSTER
eval $(maws login 398053451782_Mesosphere-PowerUser)
# The group ID of the AWS Security Group of the DC/OS public nodes
group=$(aws --region=$REGION ec2 describe-instances | jq --raw-output ".Reservations[].Instances[] | select((.Tags | length) > 0) | select(.Tags[].Value | test(\"${CLUSTER}-publicagent\")) | select(.State.Name | test(\"running\")) | .SecurityGroups[] | [.GroupName, .GroupId] | \"\(.[0]) \(.[1])\"" | grep public-agents-lb-firewall | awk '{ print $2 }' | sort -u)
./scripts/create-and-attach-volumes.sh
./scripts/create-csi-iam-policy.sh
./scripts/update-aws-network-configuration.sh ${clusters} ${loadbalancer} ${group}
dcos package install --yes --cli dcos-enterprise-cli
nodes=$(dcos node --json | jq --raw-output ".[] | select((.type | test(\"agent\")) and (.attributes.public_ip == null)) | .id" | wc -l | awk '{ print $1 }')
sed "s/NODES/${nodes}/g" scripts/options-portworx.json.template > scripts/options-portworx.json
./scripts/deploy-portworx.sh
./scripts/deploy-kubernetes-mke.sh
./scripts/check-kubernetes-mke-status.sh
./create-pool-edgelb-all.sh ${clusters}
./scripts/deploy-edgelb.sh
./scripts/check-app-status.sh infra/network/dcos-edgelb/pools/all
sed "/mesos.lab/d" /etc/hosts > ./hosts
awk -v clusters=${clusters} 'BEGIN { for (i=1; i<=clusters; i++) printf("%02d\n", i) }' | while read i; do
echo "$PUBLICIP ${APPNAME}.prod.k8s.cluster${i}.mesos.lab" >>./hosts
done
sudo mv hosts /etc/hosts