-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.gitlab-ci.yml
145 lines (136 loc) · 4.34 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
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
image: docker:latest
services:
- docker:dind
variables:
DOCKER_DRIVER: overlay
# GKE INFO
CLUSTER_NAME: ${GKE_CLUSTER}
ZONE: ${GKE_ZONE}
PROJECT: ${GKE_PROJECT_ID}
# CONTAINER INFO
CHART_PATH: k8s-bospull
CONTAINER_IMAGE: registry.gitlab.com/${CI_PROJECT_PATH}
CONTAINER_IMAGE_BUILT: ${CONTAINER_IMAGE}
CONTAINER_IMAGE_LATEST: ${CONTAINER_IMAGE}:latest
# DEPLOY
DOMAIN_NAME_STAGING: staging-bos-pull.keosd.io
DOMAIN_NAME_PROD: bos-pull.keosd.io
STAGE_NAMESPACE: bos-pull-stage
PROD_NAMESPACE: bos-pull-prod
STAGE_RELEASE_NAME: bos-pull-stage
PROD_RELEASE_NAME: bos-pull-prod
STAGE_BUCKET_NAME: gs://staging-bos-pull.keosd.io
PROD_BUCKET_NAME: gs://bos-pull.keosd.io
stages:
- build
- package
- deploy
node-build:
image: noprom/node-vue:10.8.0
stage: build
script:
- "npm install && npm update && npm run build"
only:
- master
- develop
artifacts:
name: "dist"
untracked: true
paths:
- $CI_PROJECT_DIR/dist
# docker-build:
# stage: package
# script:
# - docker build -t registry.gitlab.com/${CI_PROJECT_PATH}:$(echo ${CI_COMMIT_SHA:0-8:8}) .
# - docker login -u gitlab-ci-token -p $CI_BUILD_TOKEN registry.gitlab.com
# - docker push registry.gitlab.com/${CI_PROJECT_PATH}:$(echo ${CI_COMMIT_SHA:0-8:8})
# after_script:
# - docker images|grep none|awk '{print $3}'|xargs docker rmi
# - echo "commit:${CI_COMMIT_SHA:0-8:8}"
# dependencies:
# - node-build
# only:
# - master
# - develop
# k8s-staging-deploy:
# image: noprom/gcloud-k8s-helm:2.8.1
# stage: deploy
# environment:
# name: staging
# url: https://${DOMAIN_NAME_STAGING}
# only:
# - prd/v0.1.0
# before_script:
# - echo "$GOOGLE_KEY" > key.json
# - gcloud auth activate-service-account --key-file key.json
# - gcloud container clusters get-credentials ${CLUSTER_NAME} --zone ${ZONE} --project ${PROJECT}
# - eval $(ssh-agent -s)
# - bash -c 'ssh-add <(echo "$CI_SSH_PRIVATE_KEY")'
# - mkdir -p ~/.ssh
# - '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
# - cd ~/ && git clone ${CI_REPOSITORY} && cd ~/${CHART_PATH} && git checkout -b ${CI_REPOSITORY_BRANCH} origin/${CI_REPOSITORY_BRANCH}
# script:
# - cd ~/${CHART_PATH} && ls && echo "commit:${CI_COMMIT_SHA:0:8}"
# - helm upgrade ${STAGE_RELEASE_NAME}
# --set image.tag=$(echo ${CI_COMMIT_SHA:0:8})
# --wait
# --namespace=${STAGE_NAMESPACE}
# --values ~/${CHART_PATH}/values.stage.yaml
# ~/${CHART_PATH}
# k8s-prod-deploy:
# image: noprom/gcloud-k8s-helm:2.8.1
# stage: deploy
# environment:
# name: production
# url: https://${DOMAIN_NAME_PROD}
# # when: manual
# only:
# - prd/v0.1.0
# before_script:
# - echo "$GOOGLE_KEY" > key.json
# - gcloud auth activate-service-account --key-file key.json
# - gcloud container clusters get-credentials ${CLUSTER_NAME} --zone ${ZONE} --project ${PROJECT}
# - eval $(ssh-agent -s)
# - bash -c 'ssh-add <(echo "$CI_SSH_PRIVATE_KEY")'
# - mkdir -p ~/.ssh
# - '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
# - cd ~/ && git clone ${CI_REPOSITORY} && cd ~/${CHART_PATH} && git checkout -b ${CI_REPOSITORY_BRANCH} origin/${CI_REPOSITORY_BRANCH}
# script:
# - cd ~/${CHART_PATH} && ls && echo "commit:${CI_COMMIT_SHA:0:8}"
# - helm upgrade ${PROD_RELEASE_NAME}
# --set image.tag=$(echo ${CI_COMMIT_SHA:0:8})
# --wait
# --namespace=${PROD_NAMESPACE}
# --values ~/${CHART_PATH}/values.yaml
# ~/${CHART_PATH}
gs-staging-deploy:
image: noprom/gcloud-k8s-helm:v2.9.2
stage: deploy
environment:
name: staging
url: https://${DOMAIN_NAME_STAGING}
dependencies:
- node-build
only:
- master
before_script:
- echo "$GOOGLE_GS_KEY" > key.json
- gcloud auth activate-service-account --key-file key.json
script:
- gsutil -m rsync -r -d dist ${STAGE_BUCKET_NAME}
gs-prod-deploy:
image: noprom/gcloud-k8s-helm:v2.9.2
stage: deploy
when: manual
environment:
name: production
url: https://${DOMAIN_NAME_PROD}
dependencies:
- node-build
only:
- master
before_script:
- echo "$GOOGLE_GS_KEY" > key.json
- gcloud auth activate-service-account --key-file key.json
script:
- gsutil -m rsync -r -d dist ${PROD_BUCKET_NAME}