-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.gitlab-ci.yml
40 lines (37 loc) · 1.42 KB
/
.gitlab-ci.yml
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
stages:
- release
- deploy
variables:
APP: ${APP_NAME}
IMAGE_NAME: ${IMAGE_NAME}
DOCKERHUB_REGISTRY: ${DOCKERHUB_REGISTRY}
DOCKERHUB_USER: ${DOCKERHUB_USER}
DOCKERHUB_PWD: ${DOCKERHUB_PWD}
NAMESPACE: ${NAMESPACE}
DEPLOY_ENV_URL: ${DEPLOY_ENV_URL}
TAG_NAME: ${CI_COMMIT_SHORT_SHA}
release:
stage: release
script:
- docker login -u ${DOCKERHUB_USER} -p ${DOCKERHUB_PWD} ${DOCKERHUB_REGISTRY}
- docker build -t "${DOCKERHUB_REGISTRY}/${DOCKERHUB_USER}/${IMAGE_NAME}":"${TAG_NAME}" -f ./.docker/Dockerfile .
- docker push "${DOCKERHUB_REGISTRY}/${DOCKERHUB_USER}/${IMAGE_NAME}":"${TAG_NAME}"
deploy:
stage: deploy
image: thisiskj/kubectl-envsubst
before_script:
- unset KUBECONFIG
variables:
CPU_LIMIT: 500m
MEMORY_LIMIT: 1024Mi
CPU_REQUEST: 200m
MEMORY_REQUEST: 256Mi
script:
- printenv
- export IMAGE_PULL_SECRET=$CI_PROJECT_NAME
- kubectl -n ${NAMESPACE} get secret ${APP} || kubectl -n ${NAMESPACE} create secret docker-registry ${APP} --docker-server=$DOCKERHUB_REGISTRY --docker-username=$DOCKERHUB_USER --docker-password=$DOCKERHUB_PWD
- envsubst < ./manifests/serviceAccount.yaml | kubectl apply -f -
- envsubst < ./manifests/env.yaml | kubectl apply --validate=false -f -
- envsubst < ./manifests/deployment.yaml | kubectl apply -f -
- envsubst < ./manifests/service.yaml | kubectl apply -f -
- envsubst < ./manifests/ingress.yaml | kubectl apply -f -