-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathdeploy-3clusters.sh
executable file
·83 lines (70 loc) · 4.69 KB
/
deploy-3clusters.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
#!/bin/bash
set -e
# note that the character '_' is an invalid value if you are replacing the defaults below
cluster1_context="cluster1"
cluster2_context="cluster2"
cluster3_context="cluster3"
mgmt_context="mgmt"
gloo_mesh_version="1.2.9"
# check to see if defined contexts exist
if [[ $(kubectl config get-contexts | grep ${mgmt_context}) == "" ]] || [[ $(kubectl config get-contexts | grep ${cluster1_context}) == "" ]] || [[ $(kubectl config get-contexts | grep ${cluster2_context}) == "" ]]; then
echo "Check Failed: Either mgmt, cluster1, and cluster2 contexts do not exist. Please check to see if you have three clusters available"
echo "Run 'kubectl config get-contexts' to see currently available contexts. If the clusters are available, please make sure that they are named correctly. Default is mgmt, cluster1, and cluster2"
exit 1;
fi
# install argocd on ${mgmt_context}, ${cluster1_context}, and ${cluster2_context}
cd bootstrap-argocd
./install-argocd.sh default ${mgmt_context}
./install-argocd.sh default ${cluster1_context}
./install-argocd.sh default ${cluster2_context}
./install-argocd.sh default ${cluster3_context}
cd ..
# wait for argo cluster rollout
./tools/wait-for-rollout.sh deployment argocd-server argocd 20 ${mgmt_context}
./tools/wait-for-rollout.sh deployment argocd-server argocd 20 ${cluster1_context}
./tools/wait-for-rollout.sh deployment argocd-server argocd 20 ${cluster2_context}
./tools/wait-for-rollout.sh deployment argocd-server argocd 20 ${cluster3_context}
# deploy mgmt, cluster1, and cluster2 cluster config aoa
#kubectl apply -f platform-owners/mgmt/mgmt-cluster-config.yaml --context ${mgmt_context}
#kubectl apply -f platform-owners/cluster1/cluster1-cluster-config.yaml --context ${cluster1_context}
#kubectl apply -f platform-owners/cluster2/cluster2-cluster-config.yaml --context ${cluster2_context}
#kubectl apply -f platform-owners/cluster3/cluster3-cluster-config.yaml --context ${cluster3_context}
# deploy mgmt, cluster1, and cluster2 environment infra app-of-apps
kubectl apply -f platform-owners/mgmt/mgmt-infra.yaml --context ${mgmt_context}
kubectl apply -f platform-owners/cluster1/cluster1-infra.yaml --context ${cluster1_context}
kubectl apply -f platform-owners/cluster2/cluster2-infra.yaml --context ${cluster2_context}
kubectl apply -f platform-owners/cluster3/cluster3-infra.yaml --context ${cluster3_context}
# wait for completion of istio install
./tools/wait-for-rollout.sh deployment istiod istio-system 10 ${cluster1_context}
./tools/wait-for-rollout.sh deployment istiod istio-system 10 ${cluster2_context}
./tools/wait-for-rollout.sh deployment istiod istio-system 10 ${cluster3_context}
# register clusters to gloo mesh
#./tools/meshctl-register-helm-argocd.sh ${mgmt_context} ${cluster1_context} ${cluster2_context} ${gloo_mesh_version}
./tools/meshctl-register-helm-argocd-3-clusters.sh ${mgmt_context} ${cluster1_context} ${cluster2_context} ${cluster3_context} ${gloo_mesh_version}
# deploy cluster1, and cluster2 environment apps aoa
#kubectl apply -f platform-owners/mgmt/mgmt-apps.yaml --context ${mgmt_context}
kubectl apply -f platform-owners/cluster1/cluster1-apps.yaml --context ${cluster1_context}
kubectl apply -f platform-owners/cluster2/cluster2-apps.yaml --context ${cluster2_context}
kubectl apply -f platform-owners/cluster3/cluster3-apps.yaml --context ${cluster3_context}
# wait for completion of bookinfo install
./tools/wait-for-rollout.sh deployment productpage-v1 default 10 ${cluster1_context}
./tools/wait-for-rollout.sh deployment productpage-v1 default 10 ${cluster2_context}
./tools/wait-for-rollout.sh deployment productpage-v1 default 10 ${cluster3_context}
# deploy mgmt, cluster1, and cluster2 mesh config aoa for 3 cluster demo (cluster1, cluster2, and cluster3)
kubectl apply -f platform-owners/mgmt/mgmt-mesh-config.yaml --context ${mgmt_context}
kubectl apply -f platform-owners/cluster1/cluster1-mesh-config.yaml --context ${cluster1_context}
kubectl apply -f platform-owners/cluster2/cluster2-mesh-config.yaml --context ${cluster2_context}
kubectl apply -f platform-owners/cluster3/cluster3-mesh-config.yaml --context ${cluster3_context}
# echo port-forward commands
echo
echo "access gloo mesh dashboard:"
echo "kubectl port-forward -n gloo-mesh svc/dashboard 8090 --context ${mgmt_context}"
echo
echo "access argocd dashboard:"
echo "kubectl port-forward svc/argocd-server -n argocd 8080:443 --context ${mgmt_context}"
echo
echo "You can use the following command to validate which cluster handles the requests:"
echo "kubectl --context ${cluster1_context} logs -l app=reviews -c istio-proxy -f"
echo "kubectl --context ${cluster2_context} logs -l app=reviews -c istio-proxy -f"
echo "kubectl --context ${cluster3_context} logs -l app=reviews -c istio-proxy -f"
echo