forked from cloud-bulldozer/metadata-collector
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_backpack.sh
executable file
·98 lines (84 loc) · 2.69 KB
/
run_backpack.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
#!/bin/bash
###
# Default settings
###
CLEANUP=true
PRIVILEGED=false
ACCOUNT=false
NAMESPACE=backpack
UUID=`uuidgen`
LABEL_NAME=""
LABEL_VALUE=""
IMAGE="quay.io/cloud-bulldozer/backpack:latest"
while getopts s:p:n:xa:t:c:u:l:v:i:h flag
do
case "${flag}" in
s) ES_SERVER=${OPTARG};;
p) ES_PORT=${OPTARG};;
n) NAMESPACE=${OPTARG};;
x) PRIVILEGED=true;;
a) ACCOUNT=${OPTARG};;
c) CLEANUP=${OPTARG};;
u) UUID=${OPTARG};;
l) LABEL_NAME=${OPTARG};;
v) LABEL_VALUE=${OPTARG};;
i) IMAGE=${OPTARG};;
h) echo "Usage: run_backpack.sh [-s ELASTICSERCH_SERVER] [-p ELASTICSEARCH_PORT] [-c true|false] [-n NAMESPACE] [-x] [-a true|false] [-u UUID] [-l LABEL_NAME] [-v LABEL_VALUE] [-i IMAGE]" ; exit ;;
?) echo "Usage: run_backpack.sh [-s ELASTICSERCH_SERVER] [-p ELASTICSEARCH_PORT] [-c true|false] [-n NAMESPACE] [-x] [-a true|false] [-u UUID] [-l LABEL_NAME] [-v LABEL_VALUE] [-i IMAGE]" ; exit 1 ;;
esac
done
echo "Running Backpack with the following options"
echo "ES Server: "$ES_SERVER
echo "ES Port: "$ES_PORT
echo "Namespace: "$NAMESPACE
echo "Privileged: "$PRIVILEGED
echo "Account: "$ACCOUNT
echo "Cleanup: "$CLEANUP
echo "UUID: "$UUID
cp backpack_daemonset.yml backpack_$UUID.yml
sed -i "s/{UUID}/$UUID/g" backpack_$UUID.yml
sed -i "s/{NAMESPACE}/$NAMESPACE/g" backpack_$UUID.yml
sed -i "s/{ELASTICSEARCH_SERVER}/-s $ES_SERVER/g" backpack_$UUID.yml
sed -i "s/{ELASTICSEARCH_PORT}/-p $ES_PORT/g" backpack_$UUID.yml
sed -i "s/{PRIV}/$PRIVILEGED/g" backpack_$UUID.yml
sed -i "s?{IMAGE}?$IMAGE?g" backpack_$UUID.yml
if [[ $ACCOUNT == "true" ]]
then
sed -i "s/{ACCOUNT}/backpack-view/g" backpack_$UUID.yml
else
sed -i "s/{ACCOUNT}/default/g" backpack_$UUID.yml
fi
if [[ $LABEL_NAME != "" && $LABEL_VALUE != "" ]]
then
cat <<EOT >> backpack_$UUID.yml
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
- key: $LABEL_NAME
operator: In
values:
- $LABEL_VALUE
EOT
fi
kubectl create namespace $NAMESPACE
if [[ $ACCOUNT == "true" ]]
then
cp backpack_role.yaml backpack_role_$UUID.yaml
sed -i "s/{NAMESPACE}/$NAMESPACE/g" backpack_role_$UUID.yaml
kubectl apply -f backpack_role_$UUID.yaml
fi
kubectl apply -f backpack_$UUID.yml
while [[ `kubectl -n backpack get pods -l=name=backpack-$UUID -o jsonpath='{range .items[*]}{.status.containerStatuses[*].ready}{"\n"}{end}' | grep false` ]]
do
sleep 15
done
if [[ $CLEANUP == "true" ]]
then
if [[ $ACCOUNT == "true" ]]
then
kubectl delete -f backpack_role_$UUID.yaml
fi
kubectl delete -f backpack_$UUID.yml
fi