forked from ibm-cloud-architecture/refarch-kc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstall-app.sh
executable file
·73 lines (55 loc) · 4.14 KB
/
install-app.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
#!/bin/bash
SCRIPTLOC="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
# REPOBASE defines parent directory of the refarch-kc repo. If this script
# is moved, this path should be updated accordingly.
REPOBASE="$SCRIPTLOC/../../.."
. $SCRIPTLOC/ocpversion.sh
# Check whether an existing repo exists - if not, run the clone script
if [ ! -d "$REPOBASE/refarch-kc-order-ms" ]; then
$SCRIPTLOC/../clone.sh
fi
# Create namespace for refarch-kc microservices
kubectl create ns shipping
# Create a service account for the microservices to use
kubectl create serviceaccount -n shipping kcserviceaccount
# if [ ! -z "$OCPVERSION" ]; then
# No additional permissions required yet
# fi
# Configure secrets to allow microservices to connect to Postgres
kubectl create secret generic postgresql-url --from-literal=binding="jdbc:postgresql://postgresql.postgres.svc:5432/postgres" -n shipping
kubectl create secret generic postgresql-user --from-literal=binding="postgres" -n shipping
kubectl create secret generic postgresql-pwd --from-literal=binding="supersecret" -n shipping
# Create configmap and secret to allow container microservice to connect to BPM
# Note: you will need to modify bpm-configmap.yaml, bpm-username.txt and bpm-password.txt appropriately.
kubectl apply -f $SCRIPTLOC/bpm-configmap.yaml -n shipping
kubectl create secret generic bpm-anomaly --from-file=$SCRIPTLOC/bpm-username.txt --from-file=$SCRIPTLOC/bpm-password.txt -n shipping
# Create a configmap to allow microservices to find Kafka
# This uses port 9092 (without TLS)
kubectl create configmap kafka-brokers --from-literal=brokers="my-cluster-kafka-bootstrap.kafka.svc:9092" -n shipping
# Create configmap to configure microservices with topic names
kubectl apply -f $SCRIPTLOC/kafka-topics-configmap.yaml -n shipping
# Create Kafka topics using Strimzi CRs
kubectl apply -f $SCRIPTLOC/topics.yaml -n kafka
# Install order-command-ms using pre-built image
# note: --set eventstreams.enabled=false and --set eventstreams.truststoreRequired=false
# for connecting to Kafka rather than Event Streams
helm install order-command-ms $REPOBASE/refarch-kc-order-ms/order-command-ms/chart/ordercommandms -n shipping --set image.repository=ibmcase/kcontainer-order-command-ms --set eventstreams.enabled=false --set eventstreams.truststoreRequired=false --set serviceAccountName=kcserviceaccount
# Install order-query-ms using pre-built image
helm install order-query-ms $REPOBASE/refarch-kc-order-ms/order-query-ms/chart/orderqueryms -n shipping --set image.repository=ibmcase/kcontainer-order-query-ms --set eventstreams.enabled=false --set eventstreams.truststoreRequired=false --set serviceAccountName=kcserviceaccount
# Install spring-container-ms using pre-built image
# note: uses postgres secrets defined above
helm install spring-container-ms $REPOBASE/refarch-kc-container-ms/chart/springcontainerms -n shipping --set image.repository=ibmcase/kcontainer-spring-container-ms --set eventstreams.enabled=false --set eventstreams.truststoreRequired=false --set serviceAccountName=kcserviceaccount
# Install voyages-ms using pre-built image
helm install voyages-ms $REPOBASE/refarch-kc-ms/voyages-ms/chart/voyagesms --set image.repository=ibmcase/kcontainer-voyages-ms -n shipping --set eventstreams.enabled=false --set serviceAccountName=kcserviceaccount
# Install fleet-ms
helm install fleet-ms $REPOBASE/refarch-kc-ms/fleet-ms/chart/fleetms --set image.repository=ibmcase/kcontainer-fleet-ms -n shipping --set eventstreams.enabled=false --set eventstreams.truststoreRequired=false --set serviceAccountName=kcserviceaccount
# Install kc-ui
helm install kc-ui $REPOBASE/refarch-kc-ui/chart/kc-ui --set image.repository=ibmcase/kcontainer-ui -n shipping --set eventstreams.enabled=false --set serviceAccountName=kcserviceaccount
# Wait for all services to start
kubectl rollout status -n shipping deployment spring-container-ms
kubectl rollout status -n shipping deployment fleet-ms
kubectl rollout status -n shipping deployment kc-ui
kubectl rollout status -n shipping deployment order-command-ms
kubectl rollout status -n shipping deployment order-query-ms
kubectl rollout status -n shipping deployment voyages-ms
# call $SCRIPTLOC/postinstall.sh