-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathinit.sh
executable file
·75 lines (59 loc) · 2.24 KB
/
init.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
#!/bin/bash
# This simple Bash script is meant to initialize your local environment.
# It does following steps:
# 1. Update local kubeconfig file
# 2. Replace Amazon ElastiCache confighuration in config map
# 3. Build application, build docker image and push to Docker Hub
# 4. Replace docker repository name in deployment
# created by Bastian Klein - [email protected]
# Disclaimer: NOT FOR PRODUCTION USE - Only for demo and testing purposes
ERROR_COUNT=0;
if [[ $# -lt 1 ]] ; then
echo 'argument missing, please provide aws dev profile string (-p)'
exit 1
fi
while getopts ":r:t:u:" opt; do
case $opt in
r) REPO="$OPTARG"
;;
t) TAG="$OPTARG"
;;
u) USER="$OPTARG"
;;
\?) echo "Invalid option -$OPTARG" >&2
;;
esac
done
if ! [ -x "$(command -v aws)" ]; then
echo 'Error: aws cli is not installed.' >&2
exit 1
fi
if ! [ -x "$(command -v docker)" ]; then
echo 'Error: docker cli is not installed.' >&2
exit 1
fi
if ! [ -x "$(command -v mvn)" ]; then
echo 'Error: mvn is not installed.' >&2
exit 1
fi
if ! [ -x "$(command -v jq)" ]; then
echo 'Error: jq is not installed.' >&2
exit 1
fi
# Get EKS Cluster Name of the newly created cluster
EKS_CLUSTER_NAME=$(aws cloudformation list-exports | jq -r '.Exports[] | select(.ExportingStackId | contains("EKSJavaApplication-EKSStack")) | .Value')
# Get the Redis Database Adress
ELASTICACHE_DB_ADDRESS=$(aws cloudformation list-exports | jq -r '.Exports[] | select(.ExportingStackId | contains("EKSJavaApplication-ElastiCacheStack")) | .Value')
[[ -z "$EKS_CLUSTER_NAME" ]] && echo "Could not get EKS Cluster Name" && exit 1
[[ -z "$ELASTICACHE_DB_ADDRESS" ]] && echo "Could not get Elatiscache Address" && exit 1
# Update local kube config to use the newly created cluster
aws eks update-kubeconfig --name $EKS_CLUSTER_NAME
# Update the redsi-web-config-map for the Java Micro Service
sed -i '' -e "s/ host\: \".*\"/ host\: \"${ELASTICACHE_DB_ADDRESS}\"/g" k8s-resources/config-map.yaml
# Build & Package
mvn clean install
# Build docker images and push
docker build -t ${USER}/${REPO}:${TAG} .
docker push ${USER}/${REPO}:${TAG}
# Replace image in deployment
sed -i '' -e "s/ image\: .*/ image\: ${USER}\/${REPO}\:${TAG}/g" k8s-resources/deployment.yaml