forked from keptn-sandbox/keptn-on-k3s
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathinstall-keptn-on-k3s.sh
executable file
·1447 lines (1206 loc) · 60.1 KB
/
install-keptn-on-k3s.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
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
#!/usr/bin/env bash
set -eu
# Keptn Version Information
REPO_FOLDER=~/ace-box/keptn-on-k3s
TEMP_FOLDER=~/ace-box/tmp
CUSTOMDOMAIN=${CUSTOMDOMAIN:-none}
KEPTNVERSION=${KEPTNVERSION:-0.9.2}
KEPTN_TYPE="controlplane"
KEPTN_DELIVERYPLANE=false
KEPTN_EXECUTIONPLANE=false
KEPTN_CONTROLPLANE=true
DISABLE_BRIDGE_AUTH="false"
ISTIO_VERSION="1.9.1"
INGRESS_PORT="80"
INGRESS_PROTOCOL="http"
ISTIO_GATEWAY="public-gateway.istio-system"
ARGO_ROLLOUTS_VERSION="stable"
ARGO_ROLLOUTS_EXTENSION_VERSION="v0.10.2"
# For execution plane these are the env-variables that identify the keptn control plane
KEPTN_CONTROL_PLANE_DOMAIN=${KEPTN_CONTROL_PLANE_DOMAIN:-none}
KEPTN_CONTROL_PLANE_API_TOKEN=${KEPTN_CONTROL_PLANE_API_TOKEN:-none}
# in demo installations its likely that control plane doesnt have a valid SSL - so - we default to validate SSL false
KEPTN_CONTROL_PLANE_SSL_VERIFY=${KEPTN_CONTROL_PLANE_SSL_VERIFY:-false}
if [[ $KEPTN_CONTROL_PLANE_DOMAIN == *"live.dynatrace.com" ]]; then
# unless we connect to a dynatrace cloud automation tenant - we default to true
KEPTN_CONTROL_PLANE_SSL_VERIFY="true"
fi
# For execution plane here are the filters
KEPTN_EXECUTION_PLANE_STAGE_FILTER=${KEPTN_EXECUTION_PLANE_STAGE_FILTER:-""}
KEPTN_EXECUTION_PLANE_SERVICE_FILTER=${KEPTN_EXECUTION_PLANE_SERVICE_FILTER:-""}
KEPTN_EXECUTION_PLANE_PROJECT_FILTER=${KEPTN_EXECUTION_PLANE_PROJECT_FILTER:-""}
# PROM_SERVICE_VERSION="release-0.6.1"
# # PROM_SLI_SERVICE_VERSION="release-0.3.0" <<-- has been merged with the prometheus service
DT_SERVICE_VERSION="0.16.0"
# DT_SLI_SERVICE_VERSION="release-0.12.0" <<-- has been merged with dynatrace-service!
GENERICEXEC_SERVICE_VERSION="release-0.8.4"
MONACO_SERVICE_VERSION="release-0.9.1" # migratetokeptn08
ARGO_SERVICE_VERSION="release-0.8.4" # updates/finalize08
LOCUST_SERVICE_VERSION="release-0.1.2"
# Dynatrace Credentials
DT_TENANT=${DT_TENANT:-none}
DT_API_TOKEN=${DT_API_TOKEN:-none}
DT_PAAS_TOKEN=${DT_PAAS_TOKEN:-none}
OWNER_EMAIL=${OWNER_EMAIL:-none}
# Install Flags
PROVIDER="none"
ISTIO=${ISTIO:-true}
MY_IP="none"
FQDN="none"
KEPTN_DOMAIN="none"
PREFIX="https"
CERTS="selfsigned"
CERT_EMAIL=${CERT_EMAIL:-none}
LE_STAGE=${LE_STAGE:-none}
XIP="false"
NIP="false"
USECUSTDOMAIN="false"
INSTALL_TYPE="all" # "k3s", "keptn", "demo", "gitea"
PROM="false"
DYNA="false"
MONACO="false"
GITEA="false"
JMETER="false"
LOCUST="false"
SLACK="false"
GENERICEXEC="false"
GITEA_VERSION="v2.2.0"
DEMO="false"
# Keptn Credentials
KEPTN_API_TOKEN="$(head -c 16 /dev/urandom | base64)"
BRIDGE_PASSWORD="$(cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1)"
# k8s config
K3SVERSION="v1.19"
BINDIR="/usr/local/bin"
K3SKUBECTL=("${BINDIR}/k3s" "kubectl")
KUBECONFIG=/etc/rancher/k3s/k3s.yaml
#Gitea - default values
GIT_USER=${GIT_USER:-keptn}
GIT_PASSWORD=${GIT_SERVER:-keptn#R0cks}
GIT_SERVER=${GIT_SERVER:-none}
GIT_DOMAIN=${GIT_DOMAIN:-none}
# static vars
GIT_TOKEN="keptn-upstream-token"
TOKEN_FILE=$GIT_TOKEN.json
# keptn demo project defaults
TEMPLATE_DIRECTORY="keptn_project_templates"
KEPTN_QG_PROJECT="dynatrace"
KEPTN_QG_STAGE="quality-gate"
KEPTN_QG_SERVICE="demo"
KEPTN_PERFORMANCE_PROJECT="demo-performance"
KEPTN_PERFORMANCE_STAGE="performance"
KEPTN_PERFORMANCE_SERVICE="appundertest"
KEPTN_PERFORMANCE_EASYTRAVEL="easytravel"
KEPTN_REMEDIATION_PROJECT="demo-remediation"
KEPTN_REMEDIATION_STAGE="production"
KEPTN_REMEDIATION_SERVICE="default"
KEPTN_DELIVERY_PROJECT="demo-delivery"
KEPTN_DELIVERY_STAGE_DEV="dev"
KEPTN_DELIVERY_STAGE_STAGING="staging"
KEPTN_DELIVERY_STAGE_PRODUCTION="production"
KEPTN_DELIVERY_SERVICE="simplenode"
KEPTN_ROLLOUT_PROJECT="demo-rollout"
KEPTN_ROLLOUT_STAGE_STAGING="staging"
KEPTN_ROLLOUT_SERVICE="simplenode"
KEPTN_TWOSTAGE_DELIVERY_PROJECT="demo-twostage-delivery"
KEPTN_TWOSTAGE_DELIVERY_STAGE_STAGING="staging"
KEPTN_TWOSTAGE_DELIVERY_STAGE_PRODUCTION="production"
KEPTN_TWOSTAGE_DELIVERY_SERVICE="simplenode"
KEPTN_ADV_PERFORMANCE_PROJECT="demo-adv-performance"
KEPTN_ADV_PERFORMANCE_STAGE="performance"
KEPTN_ADV_PERFORMANCE_SERVICE="appundertest"
KEPTN_PROMETHEUS_QG_PROJECT="prometheus-qg"
KEPTN_PROMETHEUS_QG_STAGE="quality-gate"
KEPTN_PROMETHEUS_QG_SERVICE="helloservice"
KEPTN_GENERIC_AUTOMATION_PROJECT="generic-automation"
function create_namespace {
namespace="${1:-none}"
if [[ "${namespace}" == "none" ]]; then
echo "No Namespace given"
exit 1
fi
if [[ ! $("${K3SKUBECTL[@]}" get namespace "$namespace") ]]; then
"${K3SKUBECTL[@]}" create namespace "$namespace"
fi
}
function check_delete_secret {
secret="${1:-none}"
namespace="${2:-keptn}"
if [[ "${secret}" == "none" ]]; then
echo "No Secret given"
exit 1
fi
if [[ $("${K3SKUBECTL[@]}" get secret "$secret" -n "$namespace") ]]; then
"${K3SKUBECTL[@]}" delete secret "$secret" -n "$namespace"
fi
}
function get_keptn_token {
if [[ "${KEPTN_CONTROL_PLANE_API_TOKEN}" == "none" ]]; then
echo "$(${K3SKUBECTL[@]} get secret keptn-api-token -n keptn -o jsonpath={.data.keptn-api-token} | base64 -d)"
else
echo "${KEPTN_CONTROL_PLANE_API_TOKEN}"
fi
}
function write_progress {
status="${1:-default}"
echo ""
echo "#######################################>"
echo "# ${status}"
echo "#######################################>"
}
function get_ip {
write_progress "Determining IP Address"
if [[ "${MY_IP}" == "none" ]]; then
if hostname -I > /dev/null 2>&1; then
MY_IP="$(hostname -I | awk '{print $1}')"
else
echo "Could not determine ip, please specify manually"
exit 1
fi
fi
if [[ ${MY_IP} =~ ^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
echo "Detected IP: ${MY_IP}"
else
echo "${MY_IP} is not a valid ip address"
exit 1
fi
}
function get_xip_address {
address="${1:-none}"
if [[ $address != none ]]; then
echo "${address}.xip.io"
else
echo "No address given"
exit 1
fi
}
function get_nip_address {
address="${1:-none}"
if [[ $address != none ]]; then
echo "${address}.nip.io"
else
echo "No address given"
exit 1
fi
}
function get_fqdn {
if [[ "$FQDN" == "none" ]]; then
FQDN="${MY_IP}"
if [[ "${USECUSTDOMAIN}" == "true" ]]; then
FQDN="${CUSTOMDOMAIN}"
fi
if [[ "${LE_STAGE}" == "staging" ]] || [[ "${NIP}" == "true" ]]; then
FQDN="$(get_nip_address "${MY_IP}")"
fi
if [[ "${LE_STAGE}" == "production" ]]; then
echo "Issuing Production LetsEncrypt Certificates with nip.io as domain is not possible"
exit 1
fi
fi
KEPTN_DOMAIN="keptn.${FQDN}"
# if GIT_DOMAIN wasnt set and we will install GITEA lets create the domain name
if [[ "${GIT_DOMAIN}" == "none" ]] && [[ "${GITEA}" == "true" ]]; then
GIT_DOMAIN="git.${FQDN}"
# always acceses git via http as we otherwise may have problem with self-signed certificate!
GIT_SERVER="http://$GIT_DOMAIN"
fi
}
function apply_manifest {
if [[ ! -z $1 ]]; then
"${K3SKUBECTL[@]}" apply -f "${1}"
if [[ $? != 0 ]]; then
echo "Error applying manifest $1"
exit 1
fi
fi
}
function apply_manifest_ns_keptn {
if [[ ! -z $1 ]]; then
"${K3SKUBECTL[@]}" apply -n keptn -f "${1}"
if [[ $? != 0 ]]; then
echo "Error applying manifest $1"
exit 1
fi
fi
}
function get_kubectl {
if ! [ -x "$(command -v kubectl)" ]; then
write_progress "Installing kubectl"
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"
sudo install -o root -g root -m 0755 kubectl /usr/local/bin/kubectl
fi
}
function get_k3s {
write_progress "Installing K3s (${K3SVERSION}) with NGINX instead of Traefik Ingress"
curl -sfL https://get.k3s.io | INSTALL_K3S_CHANNEL="${K3SVERSION}" INSTALL_K3S_SYMLINK="skip" K3S_KUBECONFIG_MODE="644" INSTALL_K3S_EXEC="--disable=traefik" sh -
# set the kubeconfig
export KUBECONFIG=/etc/rancher/k3s/k3s.yaml
kubectl get pods -A
# install ingress nginx
helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx
helm repo update
helm install ingress-nginx ingress-nginx/ingress-nginx
# wait for nginx to be ready
}
# Installs Dynatrace OneAgent Operator on the k3s cluster
function get_oneagent {
# only install if all dynatrace settings are specified
if [[ "$DT_TENANT" == "none" ]] || [[ "$DT_API_TOKEN" == "none" ]] || [[ "$DT_PAAS_TOKEN" == "none" ]]; then
write_progress "WARNING - NOT INSTALLING Dynatrace OneAgent Operator for k3s because relevant tokens not specified!"
return;
fi
write_progress "Installing Dynatrace OneAgent Operator for k3s"
helm repo add dynatrace https://raw.githubusercontent.com/Dynatrace/helm-charts/master/repos/stable
"${K3SKUBECTL[@]}" create namespace dynatrace
kubectl apply -f https://github.com/Dynatrace/dynatrace-oneagent-operator/releases/latest/download/dynatrace.com_oneagents.yaml
kubectl apply -f https://github.com/Dynatrace/dynatrace-oneagent-operator/releases/latest/download/dynatrace.com_oneagentapms.yaml
sed -e 's~DT_TENANT~'"$DT_TENANT"'~' \
-e 's~DT_API_TOKEN~'"$DT_API_TOKEN"'~' \
-e 's~DT_PAAS_TOKEN~'"$DT_PAAS_TOKEN"'~' \
-e 's~DT_HOST_GROUP~'"$KEPTN_TYPE"'~' \
-e 's~KEPTN_TYPE~'"$KEPTN_TYPE"'~' \
-e 's~KEPTN_STAGE~'"$KEPTN_EXECUTION_PLANE_STAGE_FILTER"'~' \
$REPO_FOLDER/files/dynatrace/oneagent_values.yaml > oneagent_values.yaml
export KUBECONFIG=/etc/rancher/k3s/k3s.yaml
helm install dynatrace-oneagent-operator \
dynatrace/dynatrace-oneagent-operator -n\
dynatrace --values oneagent_values.yaml
# TODO -once ActiveGate supports local k8s API -> Install OneAgent Operator & Active Gate instead of just OneAgent Operator
# export KUBECONFIG="/etc/rancher/k3s/k3s.yaml"
# wget https://github.com/dynatrace/dynatrace-operator/releases/latest/download/install.sh -O install.sh && sh ./install.sh --api-url "https://$DT_TENANT/api" --api-token "${DT_API_TOKEN}" --paas-token "${DT_PAAS_TOKEN}" --enable-k8s-monitoring --cluster-name "keptn-on-k3s-${FQDN}"
# rm oneagent_values.yaml
}
function get_helm {
write_progress "Installing Helm 3"
curl -fsSL -o $TEMP_FOLDER/get_helm.sh https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3
chmod 700 $TEMP_FOLDER/get_helm.sh
$TEMP_FOLDER/get_helm.sh
}
function get_argorollouts {
echo "Install Argo Rollouts from ${ARGO_ROLLOUTS_VERSION}"
# First installing Argo Rollouts itself
"${K3SKUBECTL[@]}" create namespace argo-rollouts
"${K3SKUBECTL[@]}" apply -n argo-rollouts -f https://raw.githubusercontent.com/argoproj/argo-rollouts/${ARGO_ROLLOUTS_VERSION}/manifests/install.yaml
# now also installing the argo rollout extension for kubectl
curl -LO https://github.com/argoproj/argo-rollouts/releases/${ARGO_ROLLOUTS_EXTENSION_VERSION}/download/kubectl-argo-rollouts-linux-amd64
sudo chmod +x ./kubectl-argo-rollouts-linux-amd64
sudo mv ./kubectl-argo-rollouts-linux-amd64 /usr/local/bin/kubectl-argo-rollouts
}
function get_istio {
if [[ "$ISTIO" == "false" ]]; then
echo "Not installing istio as ISTIO=false"
return
fi
ISTIO_EXISTS=$(kubectl get po -n istio-system | grep Running | wc | awk '{ print $1 }')
if [[ "$ISTIO_EXISTS" -gt "0" ]]
then
echo "Istio already installed on k8s"
else
echo "Downloading and installing Istio ${ISTIO_VERSION}"
curl -L https://istio.io/downloadIstio | ISTIO_VERSION=${ISTIO_VERSION} sh -
sudo mv istio-${ISTIO_VERSION}/bin/istioctl /usr/local/bin/istioctl
istioctl install -y
write_progress "Configuring Istio Ingress Object"
sed -e 's~issuer.placeholder~'"$CERTS"'~' \
$REPO_FOLDER/files/istio/istio-ingress.yaml > istio-ingress_gen.yaml
"${K3SKUBECTL[@]}" apply -n istio-system -f istio-ingress_gen.yaml
rm istio-ingress_gen.yaml
"${K3SKUBECTL[@]}" apply -n istio-system -f $REPO_FOLDER/files/istio/istio-gateway.yaml
fi
# Create ConfigMap Entry for keptn's helm service
"${K3SKUBECTL[@]}" create configmap -n keptn ingress-config \
--from-literal=ingress_hostname_suffix=${FQDN} \
--from-literal=ingress_port=${INGRESS_PORT} \
--from-literal=ingress_protocol=${INGRESS_PROTOCOL} \
--from-literal=istio_gateway=${ISTIO_GATEWAY} \
-oyaml --dry-run | kubectl replace -f -
}
function check_k8s {
started=false
while [[ ! "${started}" ]]; do
sleep 5
if "${K3SKUBECTL[@]}" get nodes; then
started=true
fi
done
echo "k8s - Waiting for all system pods to be ready - 1st attempt (max 60s)"
"${K3SKUBECTL[@]}" wait --namespace=default --for=condition=Ready pods --timeout=60s --all
}
function disable_bridge_auth {
${K3SKUBECTL[@]} -n keptn delete secret bridge-credentials
${K3SKUBECTL[@]} -n keptn delete pods --selector=app.kubernetes.io/name=bridge
}
function install_certmanager {
# Only install cert manager if we install control or delivery plane
if [[ "${KEPTN_CONTROLPLANE}" == "false" ]] && [[ "${KEPTN_DELIVERYPLANE}" == "false" ]]; then
return
fi
write_progress "Installing Cert-Manager"
create_namespace cert-manager
helm upgrade cert-manager cert-manager --install --wait \
--create-namespace --namespace=cert-manager \
--repo="https://charts.jetstack.io" \
--kubeconfig="${KUBECONFIG}" \
--set installCRDs=true
sleep 3
cat << EOF | apply_manifest -
apiVersion: cert-manager.io/v1
kind: ClusterIssuer
metadata:
name: selfsigned-issuer
namespace: cert-manager
spec:
selfSigned: {}
EOF
check_delete_secret nginx-default-cert kube-system
cat << EOF | apply_manifest -
apiVersion: cert-manager.io/v1
kind: Certificate
metadata:
name: nginx-default
namespace: kube-system
spec:
secretName: nginx-default-cert
issuerRef:
name: selfsigned-issuer
kind: ClusterIssuer
dnsNames:
- ${MY_IP}
EOF
if [[ "$CERTS" == "letsencrypt" ]]; then
if [[ "$LE_STAGE" == "production" ]]; then
ACME_SERVER="https://acme-v02.api.letsencrypt.org/directory"
else
ACME_SERVER="https://acme-staging-v02.api.letsencrypt.org/directory"
fi
cat << EOF | apply_manifest -
apiVersion: cert-manager.io/v1
kind: ClusterIssuer
metadata:
name: letsencrypt-issuer
spec:
acme:
email: $CERT_EMAIL
server: $ACME_SERVER
privateKeySecretRef:
name: letsencrypt-issuer-account-key
solvers:
- http01:
ingress:
class: nginx
EOF
fi
"${K3SKUBECTL[@]}" rollout restart deployment ingress-nginx-controller
sleep 5
echo "Waiting for Nginx Ingress to restart - 1st attempt (max 60s)"
"${K3SKUBECTL[@]}" wait --namespace=default --for=condition=Ready pods --timeout=60s --all
}
function install_keptn {
if [[ "${KEPTN_CONTROLPLANE}" == "true" ]]; then
write_progress "Installing Keptn Control Plane"
helm upgrade keptn keptn --install --wait \
--version="${KEPTNVERSION}" \
--create-namespace --namespace=keptn \
--repo="https://storage.googleapis.com/keptn-installer" \
--set=continuous-delivery.enabled=false \
--kubeconfig="$KUBECONFIG"
fi
if [[ "${KEPTN_DELIVERYPLANE}" == "true" ]]; then
write_progress "Installing Keptn for Continuous Delivery (Control & Execution Plane)"
helm upgrade keptn keptn --install --wait \
--version="${KEPTNVERSION}" \
--create-namespace --namespace=keptn \
--repo="https://storage.googleapis.com/keptn-installer" \
--set=continuous-delivery.enabled=true \
--kubeconfig="$KUBECONFIG"
# no need to additionally install jmeter as we install a delivery plane anyway!
JMETER="false"
# need to install Istio for Delivery Plane as we are potentially depoying sevices blue / green
get_istio
get_argorollouts
# Since Keptn 0.8.2 the Helm Service and JMeter Service are no longer installed through the Keptn Helm Chart. so - installing them now
helm install jmeter-service https://github.com/keptn/keptn/releases/download/${KEPTNVERSION}/jmeter-service-${KEPTNVERSION}.tgz -n keptn
helm install helm-service https://github.com/keptn/keptn/releases/download/${KEPTNVERSION}/helm-service-${KEPTNVERSION}.tgz -n keptn
# Install the Argo Service as this is needed for one of the demo use cases
apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-contrib/argo-service/${ARGO_SERVICE_VERSION}/deploy/service.yaml"
"${K3SKUBECTL[@]}" -n keptn set env deployment/argo-service --containers=distributor PROJECT_FILTER="demo-rollout"
fi
if [[ "${KEPTN_EXECUTIONPLANE}" == "true" ]]; then
# following instructions from https://keptn.sh/docs/0.8.x/operate/multi_cluster/#install-keptn-execution-plane
write_progress "Installing Keptn Execution Plane to connect to ${KEPTN_CONTROL_PLANE_DOMAIN}"
# lets make sure the keptn namespace is created
create_namespace "keptn"
# need to install Istio for Execution Plane as we potentially deliver services with Blue / Green
# Create an empty ingress-config configmap as it will be replaced by get_istio. Normally this config map gets created during the keptn install
"${K3SKUBECTL[@]}" -n keptn create configmap ingress-config
get_istio
get_argorollouts
# Install the Helm Service - and increase memory and cpu limits
curl -fsSL -o $TEMP_FOLDER/helm.values.yaml https://raw.githubusercontent.com/keptn/keptn/release-${KEPTNVERSION}/helm-service/chart/values.yaml
yq w -i $TEMP_FOLDER/helm.values.yaml "remoteControlPlane.enabled" "true"
yq w -i $TEMP_FOLDER/helm.values.yaml "remoteControlPlane.api.hostname" "${KEPTN_CONTROL_PLANE_DOMAIN}"
yq w -i $TEMP_FOLDER/helm.values.yaml "remoteControlPlane.api.token" "${KEPTN_CONTROL_PLANE_API_TOKEN}"
yq w -i $TEMP_FOLDER/helm.values.yaml "distributor.projectFilter" "${KEPTN_EXECUTION_PLANE_PROJECT_FILTER}"
yq w -i $TEMP_FOLDER/helm.values.yaml "distributor.stageFilter" "${KEPTN_EXECUTION_PLANE_STAGE_FILTER}"
yq w -i $TEMP_FOLDER/helm.values.yaml "distributor.serviceFilter" "${KEPTN_EXECUTION_PLANE_SERVICE_FILTER}"
yq w -i $TEMP_FOLDER/helm.values.yaml "remoteControlPlane.api.apiValidateTls" "${KEPTN_CONTROL_PLANE_SSL_VERIFY}"
yq w -i $TEMP_FOLDER/helm.values.yaml "resources.requests.cpu" "50m"
yq w -i $TEMP_FOLDER/helm.values.yaml "resources.requests.memory" "128Mi"
yq w -i $TEMP_FOLDER/helm.values.yaml "resources.limits.cpu" "200m"
yq w -i $TEMP_FOLDER/helm.values.yaml "resources.limits.memory" "512Mi"
helm install helm-service https://github.com/keptn/keptn/releases/download/${KEPTNVERSION}/helm-service-${KEPTNVERSION}.tgz -n keptn --create-namespace --values=$TEMP_FOLDER/helm.values.yaml
# Install the Argo Service for just the demo-rollout project
apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-contrib/argo-service/${ARGO_SERVICE_VERSION}/deploy/service.yaml"
"${K3SKUBECTL[@]}" -n keptn set env deployment/argo-service --containers=distributor PROJECT_FILTER="demo-rollout"
"${K3SKUBECTL[@]}" -n keptn set env deployment/argo-service --containers=distributor KEPTN_API_ENDPOINT="https://${KEPTN_CONTROL_PLANE_DOMAIN}/api" KEPTN_API_TOKEN="${KEPTN_CONTROL_PLANE_API_TOKEN}" HTTP_SSL_VERIFY="${KEPTN_CONTROL_PLANE_SSL_VERIFY}"
"${K3SKUBECTL[@]}" -n keptn set env deployment/argo-service --containers=distributor STAGE_FILTER="${KEPTN_EXECUTION_PLANE_STAGE_FILTER}" SERVICE_FILTER="${KEPTN_EXECUTION_PLANE_SERVICE_FILTER}" PROJECT_FILTER="${KEPTN_EXECUTION_PLANE_PROJECT_FILTER}"
# Install JMeter if the user wants to
if [[ "${JMETER}" == "true" ]]; then
curl -fsSL -o $TEMP_FOLDER/jmeter.values.yaml https://raw.githubusercontent.com/keptn/keptn/release-${KEPTNVERSION}/jmeter-service/chart/values.yaml
yq w -i $TEMP_FOLDER/jmeter.values.yaml "remoteControlPlane.enabled" "true"
yq w -i $TEMP_FOLDER/jmeter.values.yaml "remoteControlPlane.api.hostname" "${KEPTN_CONTROL_PLANE_DOMAIN}"
yq w -i $TEMP_FOLDER/jmeter.values.yaml "remoteControlPlane.api.token" "${KEPTN_CONTROL_PLANE_API_TOKEN}"
yq w -i $TEMP_FOLDER/jmeter.values.yaml "distributor.projectFilter" "${KEPTN_EXECUTION_PLANE_PROJECT_FILTER}"
yq w -i $TEMP_FOLDER/jmeter.values.yaml "distributor.stageFilter" "${KEPTN_EXECUTION_PLANE_STAGE_FILTER}"
yq w -i $TEMP_FOLDER/jmeter.values.yaml "distributor.serviceFilter" "${KEPTN_EXECUTION_PLANE_SERVICE_FILTER}"
yq w -i $TEMP_FOLDER/jmeter.values.yaml "remoteControlPlane.api.apiValidateTls" "${KEPTN_CONTROL_PLANE_SSL_VERIFY}"
helm install jmeter-service https://github.com/keptn/keptn/releases/download/${KEPTNVERSION}/jmeter-service-${KEPTNVERSION}.tgz -n keptn --create-namespace --values=$TEMP_FOLDER/jmeter.values.yaml
# no need to additionally install jmeter afterwards as we install it as part of the execution plane anyway!
JMETER="false"
fi
if [[ "${GENERICEXEC}" == "true" ]]; then
write_progress "Installing Generic Executor Service on the Execution Plane"
apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-sandbox/generic-executor-service/${GENERICEXEC_SERVICE_VERSION}/deploy/service.yaml"
"${K3SKUBECTL[@]}" -n keptn set env deployment/generic-executor-service --containers=generic-executor-service CONFIGURATION_SERVICE="http://localhost:8081/configuration-service"
"${K3SKUBECTL[@]}" -n keptn set env deployment/generic-executor-service --containers=distributor KEPTN_API_ENDPOINT="https://${KEPTN_CONTROL_PLANE_DOMAIN}/api" KEPTN_API_TOKEN="${KEPTN_CONTROL_PLANE_API_TOKEN}" HTTP_SSL_VERIFY="${KEPTN_CONTROL_PLANE_SSL_VERIFY}"
"${K3SKUBECTL[@]}" -n keptn set env deployment/generic-executor-service --containers=distributor PUBSUB_TOPIC="sh.keptn.event.deployment.triggered,sh.keptn.event.test.triggered,sh.keptn.event.evaluation.triggered,sh.keptn.event.rollback.triggered,sh.keptn.event.release.triggered,sh.keptn.event.action.triggered,sh.keptn.event.getjoke.triggered,sh.keptn.event.validate.triggered"
"${K3SKUBECTL[@]}" -n keptn set env deployment/generic-executor-service --containers=distributor STAGE_FILTER="${KEPTN_EXECUTION_PLANE_STAGE_FILTER}" SERVICE_FILTER="${KEPTN_EXECUTION_PLANE_SERVICE_FILTER}" PROJECT_FILTER="${KEPTN_EXECUTION_PLANE_PROJECT_FILTER}"
# TODO - we need to find a better way to define all events to be forwarded to the generic executor
GENERICEXEC="false"
fi
if [[ "${MONACO}" == "true" ]]; then
write_progress "Installing Monaco (Monitoring as Code) on Execution Plane"
apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-sandbox/monaco-service/${MONACO_SERVICE_VERSION}/deploy/service.yaml"
"${K3SKUBECTL[@]}" -n keptn set env deployment/monaco-service --containers=monaco-service CONFIGURATION_SERVICE="http://localhost:8081/configuration-service"
"${K3SKUBECTL[@]}" -n keptn set env deployment/monaco-service --containers=distributor KEPTN_API_ENDPOINT="https://${KEPTN_CONTROL_PLANE_DOMAIN}/api" KEPTN_API_TOKEN="${KEPTN_CONTROL_PLANE_API_TOKEN}" HTTP_SSL_VERIFY="${KEPTN_CONTROL_PLANE_SSL_VERIFY}"
"${K3SKUBECTL[@]}" -n keptn set env deployment/monaco-service --containers=distributor STAGE_FILTER="${KEPTN_EXECUTION_PLANE_STAGE_FILTER}" SERVICE_FILTER="${KEPTN_EXECUTION_PLANE_SERVICE_FILTER}" PROJECT_FILTER="${KEPTN_EXECUTION_PLANE_PROJECT_FILTER}"
# kristof: increase monaco service resources
"${K3SKUBECTL[@]}" -n keptn patch deploy monaco-service --type json -p='[{"op": "replace", "path": "/spec/template/spec/containers/0/resources/limits/memory", "value":"1Gi"}]'
"${K3SKUBECTL[@]}" -n keptn patch deploy monaco-service --type json -p='[{"op": "replace", "path": "/spec/template/spec/containers/0/resources/limits/cpu", "value":"2"}]'
fi
# Install Locust if the user wants to
if [[ "${LOCUST}" == "true" ]]; then
apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-sandbox/locust-service/${LOCUST_SERVICE_VERSION}/deploy/service.yaml"
"${K3SKUBECTL[@]}" -n keptn set env deployment/locust-service --containers=locust-service CONFIGURATION_SERVICE="http://localhost:8081/configuration-service"
"${K3SKUBECTL[@]}" -n keptn set env deployment/locust-service --containers=distributor KEPTN_API_ENDPOINT="https://${KEPTN_CONTROL_PLANE_DOMAIN}/api" KEPTN_API_TOKEN="${KEPTN_CONTROL_PLANE_API_TOKEN}" HTTP_SSL_VERIFY="${KEPTN_CONTROL_PLANE_SSL_VERIFY}"
fi
fi
if [[ "${PROM}" == "true" ]]; then
write_progress "Installing Prometheus"
helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
"${K3SKUBECTL[@]}" create ns prometheus
helm install prometheus prometheus-community/prometheus --namespace prometheus
write_progress "Installing Prometheus Service"
"${K3SKUBECTL[@]}" apply -f "https://raw.githubusercontent.com/keptn-contrib/prometheus-service/${PROM_SERVICE_VERSION}/deploy/role.yaml" -n prometheus
apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-contrib/prometheus-service/${PROM_SERVICE_VERSION}/deploy/service.yaml"
"${K3SKUBECTL[@]}" set env deploy/prometheus-service --containers=prometheus-service PROMETHEUS_NS=prometheus ALERT_MANAGER_NS=prometheus -n keptn
fi
# Install Dynatrace Services
if [[ "${DYNA}" == "true" ]]; then
if [[ "${KEPTN_CONTROLPLANE}" == "true" ]] || [[ "${KEPTN_DELIVERYPLANE}" == "true" ]]; then
write_progress "Installing Dynatrace SLI Services on Control / Delivery Plane"
# Installing core dynatrace services
helm upgrade --install dynatrace-service -n keptn https://github.com/keptn-contrib/dynatrace-service/releases/download/${DT_SERVICE_VERSION}/dynatrace-service-${DT_SERVICE_VERSION}.tgz --set dynatraceService.config.keptnApiUrl=${PREFIX}://${KEPTN_DOMAIN}/api --set dynatraceService.config.keptnBridgeUrl=${PREFIX}://${KEPTN_DOMAIN}/bridge
# apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-contrib/dynatrace-service/${DT_SERVICE_VERSION}/deploy/service.yaml"
# apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-contrib/dynatrace-sli-service/${DT_SLI_SERVICE_VERSION}/deploy/service.yaml"
# lets make Dynatrace the default SLI provider (feature enabled with lighthouse 0.7.2)
"${K3SKUBECTL[@]}" create configmap lighthouse-config -n keptn --from-literal=sli-provider=dynatrace || true
fi
fi
# Install Monaco Service
if [[ "${MONACO}" == "true" ]]; then
if [[ "${KEPTN_DELIVERYPLANE}" == "true" ]] ; then
# Installing monaco service on deliveryplane
write_progress "Installing Monaco (Monitoring as Code) on Delivery Plane"
apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-sandbox/monaco-service/${MONACO_SERVICE_VERSION}/deploy/service.yaml"
fi
fi
if [[ "${GITEA}" == "true" ]]; then
write_progress "Installing Gitea for upstream git"
helm repo add gitea-charts https://dl.gitea.io/charts/
# removing any previous git-token files that might be left-over from a previous install
if [ -f "${TOKEN_FILE}" ]; then
rm "${TOKEN_FILE}"
fi
echo "Create namespace for git"
"${K3SKUBECTL[@]}" create ns git
# Download helm yaml
sed -e 's~domain.placeholder~'"$GIT_DOMAIN"'~' \
-e 's~GIT_USER.placeholder~'"$GIT_USER"'~' \
-e 's~GIT_PASSWORD.placeholder~'"$GIT_PASSWORD"'~' \
$REPO_FOLDER/files/gitea/helm-gitea.yaml > helm-gitea_gen.yaml
echo "Install gitea via Helmchart"
helm install gitea gitea-charts/gitea --version "${GITEA_VERSION}" -f helm-gitea_gen.yaml --namespace git --kubeconfig="${KUBECONFIG}"
rm helm-gitea_gen.yaml
write_progress "Configuring Gitea Ingress Object (${GIT_DOMAIN})"
sed -e 's~domain.placeholder~'"$GIT_DOMAIN"'~' \
-e 's~issuer.placeholder~'"$CERTS"'~' \
$REPO_FOLDER/files/gitea/gitea-ingress.yaml > gitea-ingress_gen.yaml
"${K3SKUBECTL[@]}" apply -n git -f gitea-ingress_gen.yaml
rm gitea-ingress_gen.yaml
write_progress "Waiting for Gitea pods to be ready (max 5 minutes)"
"${K3SKUBECTL[@]}" wait --namespace=git --for=condition=Ready pods --timeout=300s --all
fi
if [[ "${GENERICEXEC}" == "true" ]]; then
write_progress "Installing Generic Executor Service"
apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-sandbox/generic-executor-service/${GENERICEXEC_SERVICE_VERSION}/deploy/service.yaml"
fi
if [[ "${SLACK}" == "true" ]]; then
write_progress "Installing SlackBot Service"
apply_manifest_ns_keptn "https://raw.githubusercontent.com/keptn-sandbox/slackbot-service/0.2.0/deploy/slackbot-service.yaml"
check_delete_secret slackbot
"${K3SKUBECTL[@]}" create secret generic -n keptn slackbot --from-literal="slackbot-token=$SLACKBOT_TOKEN"
fi
# Installing JMeter Service on the control plane if requested!
if [[ "${JMETER}" == "true" ]]; then
write_progress "Installing JMeter Service"
helm install jmeter-service https://github.com/keptn/keptn/releases/download/${KEPTNVERSION}/jmeter-service-${KEPTNVERSION}.tgz -n keptn --create-namespace
fi
if [[ "${DISABLE_BRIDGE_AUTH}" == "true" ]]; then
disable_bridge_auth
fi
write_progress "Waiting for Keptn pods to be ready (max 5 minutes)"
sleep 30
"${K3SKUBECTL[@]}" wait --namespace=keptn --for=condition=Ready pods --timeout=60s --all || true
# Keptn Ingress only makes sense if we actually installed the keptn control or delivery plane
if [[ "${KEPTN_DELIVERYPLANE}" == "true" ]] || [[ "${KEPTN_CONTROLPLANE}" == "true" ]]; then
write_progress "Configuring Keptn Ingress Object (${KEPTN_DOMAIN})"
sed -e 's~domain.placeholder~'"$KEPTN_DOMAIN"'~' \
-e 's~issuer.placeholder~'"$CERTS"'~' \
$REPO_FOLDER/files/keptn/keptn-ingress.yaml > keptn-ingress_gen.yaml
"${K3SKUBECTL[@]}" apply -n keptn -f keptn-ingress_gen.yaml
rm keptn-ingress_gen.yaml
write_progress "Waiting for certificates to be ready (max 5 minutes)"
"${K3SKUBECTL[@]}" wait --namespace=keptn --for=condition=Ready certificate keptn-tls --timeout=300s
fi
# For Dynatrace or Monaco create the secret. Has to be at the end as keptn_create_dynatrace_secret calls the Keptn API
if [[ "${DYNA}" == "true" ]] || [[ "${MONACO}" == "true" ]]; then
write_progress "Creating Dynatrace Secret!"
# Always create the secret in Keptn as a secret
keptn_create_dynatrace_secret
# As of today (Keptn 0.8.4) we also have to create the secret as a k8s secret on the execution plane as keptn secrets are not yet propagated!
if [[ "${KEPTN_EXECUTIONPLANE}" == "true" ]]; then
check_delete_secret dynatrace
"${K3SKUBECTL[@]}" create secret generic -n keptn dynatrace \
--from-literal="DT_TENANT=$DT_TENANT" \
--from-literal="DT_API_TOKEN=$DT_API_TOKEN"
fi
fi
}
function get_keptncredentials {
# If we are on the execution plane we can connect the keptn CLI to the Control Plane
if [[ "${KEPTN_EXECUTIONPLANE}" == "true" ]]; then
KEPTN_DOMAIN="${KEPTN_CONTROL_PLANE_DOMAIN}"
KEPTN_API_TOKEN="${KEPTN_CONTROL_PLANE_API_TOKEN}"
else
KEPTN_API_TOKEN="$(get_keptn_token)"
fi
}
function install_keptncli {
echo "Installing the Keptn CLI"
curl -sL https://get.keptn.sh | KEPTN_VERSION=${KEPTNVERSION} sudo -E bash
get_keptncredentials
keptn auth --api-token "${KEPTN_API_TOKEN}" --endpoint "${PREFIX}://$KEPTN_DOMAIN/api"
}
# Following are functions based on Gitea Documentation
# https://gitea.com/gitea/helm-chart/#configuration
# Load git vars
# Create Token
gitea_createApiToken(){
echo "Creating token for $GIT_USER from $GIT_SERVER"
curl -vkL --user $GIT_USER:$GIT_PASSWORD \
-X POST "$GIT_SERVER/api/v1/users/$GIT_USER/tokens" \
-H "accept: application/json" -H "Content-Type: application/json; charset=utf-8" \
-d "{ \"name\": \"$GIT_TOKEN\" }" -o $TOKEN_FILE
}
gitea_getApiTokens(){
echo "Get tokens for $GIT_USER from $GIT_SERVER"
curl -vkL --user $GIT_USER:$GIT_PASSWORD \
-X GET "$GIT_SERVER/api/v1/users/$GIT_USER/tokens" \
-H "accept: application/json" -H "Content-Type: application/json; charset=utf-8"
}
gitea_deleteApiToken(){
echo "Deleting token for $GIT_USER from $GIT_SERVER"
curl -vkL --user $GIT_USER:$GIT_PASSWORD \
-X DELETE "$GIT_SERVER/api/v1/users/$GIT_USER/tokens/$TOKEN_ID" \
-H "accept: application/json" -H "Content-Type: application/json; charset=utf-8"
}
gitea_readApiTokenFromFile() {
if [ ! -f "$TOKEN_FILE" ]; then
gitea_createApiToken
fi
if [ -f "$TOKEN_FILE" ]; then
echo "Reading token from file $TOKEN_FILE"
TOKENJSON=$(cat $TOKEN_FILE)
API_TOKEN=$(echo $TOKENJSON | jq -r '.sha1')
TOKEN_ID=$(echo $TOKENJSON | jq -r '.id')
echo "tokenId: $TOKEN_ID hash: $API_TOKEN"
else
echo "Cant get Git Token!"
fi
}
gitea_createKeptnRepos() {
echo "Creating repositories for Keptn projects "
for project in `keptn get projects | awk '{ if (NR!=1) print $1}'`;
do
gitea_createKeptnRepo $project || true
done
}
gitea_updateKeptnRepo(){
KEPTN_PROJECT=$1
keptn update project $KEPTN_PROJECT --git-user=$GIT_USER --git-token=$API_TOKEN --git-remote-url=$GIT_SERVER/$GIT_USER/$KEPTN_PROJECT.git
}
gitea_createKeptnRepoManually(){
gitea_readApiTokenFromFile
gitea_createKeptnRepo $1
}
gitea_createKeptnRepo(){
echo "Creating and migrating Keptn project to self-hosted git for $1"
gitea_createGitRepo $1
gitea_updateKeptnRepo $1
}
gitea_createGitRepo(){
echo "Create repo for project $1"
# Create Repo with Token
curl -k -X POST "$GIT_SERVER/api/v1/user/repos?access_token=$API_TOKEN" \
-H "accept: application/json" -H "Content-Type: application/json" \
-d "{ \"auto_init\": false, \"default_branch\": \"master\", \"name\": \"$1\", \"private\": false}"
}
function check_dynatrace_credentials {
echo "Enabling Dynatrace or Monaco Support: Requires you to set DT_TENANT, DT_API_TOKEN"
if [[ "$DT_TENANT" == "none" ]]; then
echo "You have to set DT_TENANT to your Tenant URL, e.g: abc12345.dynatrace.live.com or yourdynatracemanaged.com/e/abcde-123123-asdfa-1231231"
echo "To learn more about the required settings please visit https://keptn.sh/docs/0.7.x/monitoring/dynatrace/install"
exit 1
fi
if [[ "$DT_API_TOKEN" == "none" ]]; then
echo "You have to set DT_API_TOKEN to a Token that has read/write configuration, access metrics, log content and capture request data priviliges"
echo "If you want to learn more please visit https://keptn.sh/docs/0.7.x/monitoring/dynatrace/install"
exit 1
fi
if [[ "$DYNA" == "true" ]] && [[ "$DT_PAAS_TOKEN" == "none" ]]; then
echo "You have to set DT_PAAS_TOKEN to a PAAS Token that will be used to deploy the Dynatrace OneAgent on the k3s cluster"
echo "Without that you wont have any monitoring of that cluster which will prohibit some of the dynatrace demos"
echo "If you want to learn more please visit https://www.dynatrace.com/support/help/technology-support/cloud-platforms/kubernetes/deploy-oneagent-k8/"
exit 1
fi
# Adding output as following curl may fail if DT_TENANT is resulting in an invalid curl
echo "Running a check if Dynatrace API is reachable on https://$DT_TENANT/api/v1/config/clusterversion"
echo "If script stops here please double check your DT_TENANT. It should be e,g: abc12345.dynatrace.live.com or yourdynatracemanaged.com/e/abcde-123123-asdfa-1231231"
# Validate tenant and token is correct
status=$(curl --request GET \
--url "https://$DT_TENANT/api/v1/config/clusterversion" \
--header "Authorization: Api-Token $DT_API_TOKEN" \
--write-out %{http_code} --silent --output /dev/null)
if [[ $status != 200 ]]; then
echo "Couldnt connect to the Dynatrace API with provided DT_TENANT & DT_API_TOKEN"
echo "Please double check the URL to not include leading https:// and double check your API_TOKEN priviliges"
echo "To try this yourself try to get to: https://$DT_TENANT/api/v1/config/clusterversion"
exit 1
fi
}
#
# Creates a Keptn Secret including DT_API_TOKEN AND DT_TENANT as name/value pairs
# 1. secret_name (optional). Default is dynatrace
# 2. scope (optional). Default is keptn-default
#
function keptn_create_dynatrace_secret {
secret_name="${1:-dynatrace}"
scope="${2:-keptn-default}"
get_keptncredentials
# CREATE Keptn Secret
echo "Calling HTTP POST ${PREFIX}://${KEPTN_DOMAIN}/api/secrets/v1/secret"
curl -k -X POST "${PREFIX}://${KEPTN_DOMAIN}/api/secrets/v1/secret" -H "accept: application/json" -H "x-token: ${KEPTN_API_TOKEN}" -H "Content-Type: application/json" -d "{ \"data\": { \"DT_TENANT\": \"${DT_TENANT}\", \"DT_API_TOKEN\": \"${DT_API_TOKEN}\" }, \"name\": \"${secret_name}\", \"scope\": \"${scope}\"}"
}
function install_demo_dynatrace {
write_progress "Installing Dynatrace Demo Projects"
# ==============================================================================================
# Demo 1: Create a quality-gate project called "dynatrace"
# Setup based on https://github.com/keptn-contrib/dynatrace-sli-service/tree/master/dashboard
# This project also enables the auto-synchronization capability as explained here: https://github.com/keptn-contrib/dynatrace-service#synchronizing-service-entities-detected-by-dynatrace
# ==============================================================================================
get_keptncredentials
export KEPTN_ENDPOINT="${PREFIX}://${KEPTN_DOMAIN}"
export KEPTN_INGRESS=${FQDN}
echo "----------------------------------------------"
echo "Create Keptn Project: ${KEPTN_QG_PROJECT}"
./create-keptn-project-from-template.sh quality-gate-dynatrace ${OWNER_EMAIL} ${KEPTN_QG_PROJECT}
echo "Run first Dynatrace Quality Gate"
keptn trigger evaluation --project="${KEPTN_QG_PROJECT}" --stage="${KEPTN_QG_STAGE}" --service="${KEPTN_QG_SERVICE}" --timeframe=30m
# ==============================================================================================
# Demo 2: Performance as a Self-service Project
# Creates a single stage project that will execute JMeter performance tests against any URL you give it
# To get Keptn also send events to a Dynatrace Monitored Entity simply tag the entity with ${KEPTN_QG_STAGE}
# ==============================================================================================
echo "----------------------------------------------"
echo "Create Keptn Project: ${KEPTN_PERFORMANCE_PROJECT}"
./create-keptn-project-from-template.sh performance-as-selfservice ${OWNER_EMAIL} ${KEPTN_PERFORMANCE_PROJECT}
# ==============================================================================================
# Demo 3: Auto-Remediation
# Creates a single stage project with a service that will map to all incoming problem types, e.g: infrastructure, applcation ...
# The service will have its own remediation.yaml to execute remediation scripts
# This demo will leverage the generic-executor-service to execute bash or python scripts for remediation
# ==============================================================================================
echo "----------------------------------------------"
echo "Create Keptn Project: ${KEPTN_REMEDIATION_PROJECT}"
./create-keptn-project-from-template.sh auto-remediation ${OWNER_EMAIL} ${KEPTN_REMEDIATION_PROJECT}
# ==============================================================================================
# Demo 4: Blue/Green Delivery with Istio
# Creates a 3 stage delivery project to delivery the singlenode sample app in dev, staging and production
# ==============================================================================================
echo "----------------------------------------------"
echo "Create Keptn Project: ${KEPTN_DELIVERY_PROJECT}"
./create-keptn-project-from-template.sh delivery-simplenode ${OWNER_EMAIL} ${KEPTN_DELIVERY_PROJECT}
# ==============================================================================================
# Demo 5: Canary Delivery with Argo Rollouts
# Creates canary delivery project using Argo Rollouts
# ==============================================================================================
echo "----------------------------------------------"
echo "Create Keptn Project: ${KEPTN_ROLLOUT_PROJECT}"
./create-keptn-project-from-template.sh delivery-rollout ${OWNER_EMAIL} ${KEPTN_ROLLOUT_PROJECT}
# ==============================================================================================
# Demo 6: Advanced Performance
# Creates a project with 3 sequences of performance testing: functional, simple load, performance
# ==============================================================================================
echo "----------------------------------------------"
echo "Create Keptn Project: ${KEPTN_ADV_PERFORMANCE_PROJECT}"
./create-keptn-project-from-template.sh advanced-performance ${OWNER_EMAIL} ${KEPTN_ADV_PERFORMANCE_PROJECT}
# ==============================================================================================
# Demo 7: Generic Automation
# Creates a project that just shows generic automation sequences, e.g: calling some scripts
# ==============================================================================================
echo "----------------------------------------------"
echo "Create Keptn Project: ${KEPTN_GENERIC_AUTOMATION_PROJECT}"
./create-keptn-project-from-template.sh generic-automation ${OWNER_EMAIL} ${KEPTN_GENERIC_AUTOMATION_PROJECT}
# ==============================================================================================
# Demo 8: Two Stage Delivery
# Creates a project that uses a regular helm chart for two stage delivery
# ==============================================================================================
echo "----------------------------------------------"
echo "Create Keptn Project: ${KEPTN_TWOSTAGE_DELIVERY_PROJECT}"
./create-keptn-project-from-template.sh two-stage-delivery-simplenode ${OWNER_EMAIL} ${KEPTN_TWOSTAGE_DELIVERY_PROJECT}
}
function install_demo {
echo "Installing Demos"
if [[ "${DEMO}" == "dynatrace" ]]; then
install_demo_dynatrace
fi
if [[ "${DEMO}" == "prometheus" ]]; then
install_prometheus_qg_demo
fi
}
function install_prometheus_qg_demo {
write_progress "Installing Prometheus Demo Projects"
export KEPTN_ENDPOINT="${PREFIX}://${KEPTN_DOMAIN}"
export KEPTN_INGRESS=${FQDN}
echo "----------------------------------------------"
echo "Create Keptn Project: ${KEPTN_PROMETHEUS_QG_PROJECT}"
./create-keptn-project-from-template.sh prometheus-qg ${CERT_EMAIL} ${KEPTN_PROMETHEUS_QG_PROJECT}
"${K3SKUBECTL[@]}" create secret -n keptn generic "prometheus-credentials-${KEPTN_PROMETHEUS_QG_PROJECT}" --from-file=prometheus-credentials="${TEMPLATE_DIRECTORY}/${KEPTN_PROMETHEUS_QG_PROJECT}/sli-secret.yaml"
"${K3SKUBECTL[@]}" delete pod -n keptn --selector=run=prometheus-sli-service
"${K3SKUBECTL[@]}" create ns prometheus-qg-quality-gate
"${K3SKUBECTL[@]}" apply -f "${TEMPLATE_DIRECTORY}/${KEPTN_PROMETHEUS_QG_PROJECT}/podtato-head/deployment.yaml"
"${K3SKUBECTL[@]}" apply -f "${TEMPLATE_DIRECTORY}/${KEPTN_PROMETHEUS_QG_PROJECT}/podtato-head/service.yaml"