-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path.gitlab-ci.yml
115 lines (109 loc) ยท 3.53 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
stages:
- create-env
- frontend-build
- backend-build
- docker-build
- docker-pull
variables:
DOCKER_COMPOSE_FILE: docker-compose.yml
create-env:
stage: create-env
script:
# front
- echo "DOCKER_USERNAME = ${DOCKER_USERNAME}" >> .env
- echo "DOCKER_REPO = ${DOCKER_REPO}" >> .env
# back
- echo "DB_URL=${DB_URL}" >> .env
- echo "DB_NAME=${DB_NAME}" >> .env
- echo "DB_USERNAME=${DB_USERNAME}" >> .env
- echo "DB_PASSWORD=${DB_PASSWORD}" >> .env
- echo "REDIS_HOST = ${REDIS_HOST}" >> .env
- echo "REDIS_PORT = ${REDIS_PORT}" >> .env
- echo "REDIS_PASSWORD = ${REDIS_PASSWORD}" >> .env
- echo "JWT_SECRET = ${JWT_SECRET}" >> .env
- echo "OAUTH2_SECRET_GOOGLE = ${OAUTH2_SECRET_GOOGLE}" >> .env
- echo "OAUTH2_SECRET_NAVER = ${OAUTH2_SECRET_NAVER}" >> .env
- echo "OAUTH2_SECRET_KAKAO = ${OAUTH2_SECRET_KAKAO}" >> .env
- echo "S3_ACCESS_KEY = ${S3_ACCESS_KEY}" >> .env
- echo "S3_BUCKET = ${S3_BUCKET}" >> .env
- echo "S3_REGION = ${S3_REGION}" >> .env
- echo "S3_SECRET_KEY = ${S3_SECRET_KEY}" >> .env
- echo "DOCKER_USERNAME = ${DOCKER_USERNAME}" >> .env
- echo "DOCKER_REPO = ${DOCKER_REPO}" >> .env
- echo "OPENVIDU_URL = ${OPENVIDU_URL}" >> .env
- echo "OPENVIDU_SECRET = ${OPENVIDU_SECRET}" >> .env
artifacts:
paths:
- .env
only:
- deploy
frontend-build:
stage: frontend-build
image: node:18-alpine
script:
- cd frontend
- npm install
- npm run build
artifacts:
paths:
- frontend/dist
only:
- frontend-deploy
backend-build:
stage: backend-build
image: gradle:jdk17
script:
- cd backend
- cd mokkoji
- chmod +x gradlew
- ./gradlew clean build
cache:
paths:
- .gradle/wrapper
- .gradle/caches
artifacts:
paths:
- backend/mokkoji/build/libs/mokkoji-0.0.1-SNAPSHOT.jar
only:
- deploy
docker-build:
stage: docker-build
dependencies:
- create-env
- frontend-build
- backend-build
script:
# image removal
- docker rmi ${DOCKER_USERNAME}/${DOCKER_REPO}:backend-latest || true
# login
- docker login -u ${DOCKER_USERNAME} -p ${DOCKER_PASSWORD}
# frontend push
- cd frontend
- docker build -t ${DOCKER_USERNAME}/${DOCKER_REPO}:frontend-latest -f Dockerfile .
- docker push ${DOCKER_USERNAME}/${DOCKER_REPO}:frontend-latest
# backend push
- cd backend
- cd mokkoji
- docker build -t ${DOCKER_USERNAME}/${DOCKER_REPO}:backend-latest -f Dockerfile .
- docker push ${DOCKER_USERNAME}/${DOCKER_REPO}:backend-latest
only:
- deploy
docker-pull:
stage: docker-pull
script:
# login again
- docker login -u ${DOCKER_USERNAME} -p ${DOCKER_PASSWORD}
# container removal
- docker stop $(docker ps -q --filter ancestor=${DOCKER_USERNAME}/${DOCKER_REPO}:frontend-latest) || true
- docker stop $(docker ps -q --filter ancestor=${DOCKER_USERNAME}/${DOCKER_REPO}:backend-latest) || true
- docker rm $(docker ps -aq --filter ancestor=${DOCKER_USERNAME}/${DOCKER_REPO}:frontend-latest) || true
- docker rm $(docker ps -aq --filter ancestor=${DOCKER_USERNAME}/${DOCKER_REPO}:backend-latest) || true
- docker-compose -f $DOCKER_COMPOSE_FILE down || true
- docker rmi $(docker images -q ${DOCKER_USERNAME}/${DOCKER_REPO}:frontend-latest) || true
- docker rmi $(docker images -q ${DOCKER_USERNAME}/${DOCKER_REPO}:backend-latest) || true
# deploy
- docker-compose -f $DOCKER_COMPOSE_FILE pull
- docker-compose -f $DOCKER_COMPOSE_FILE up -d
- docker image prune -f
only:
- deploy