|
1 | 1 | name: FE ADMIN CI / CD
|
2 | 2 |
|
3 | 3 | on:
|
4 |
| - push: |
5 |
| - branches: |
6 |
| - - fe |
| 4 | + push: |
| 5 | + branches: |
| 6 | + - fe |
7 | 7 |
|
8 | 8 | jobs:
|
9 |
| - CI: |
10 |
| - runs-on: ubuntu-latest |
| 9 | + CI: |
| 10 | + runs-on: ubuntu-latest |
11 | 11 |
|
12 |
| - env: |
13 |
| - GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} |
14 |
| - IMAGE_NAME: uniro-backoffice |
15 |
| - IMAGE_TAG: ${{ github.sha }} |
| 12 | + env: |
| 13 | + GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} |
| 14 | + IMAGE_NAME: uniro-backoffice |
| 15 | + IMAGE_TAG: ${{ github.sha }} |
16 | 16 |
|
17 |
| - steps: |
18 |
| - - name: 코드 체크아웃 |
19 |
| - uses: actions/checkout@v4 |
| 17 | + steps: |
| 18 | + - name: 코드 체크아웃 |
| 19 | + uses: actions/checkout@v4 |
20 | 20 |
|
21 |
| - - name: Google Cloud SDK 설정 |
22 |
| - uses: "google-github-actions/auth@v2" |
23 |
| - with: |
24 |
| - credentials_json: ${{ secrets.GCP_SA_KEY }} |
| 21 | + - name: Google Cloud SDK 설정 |
| 22 | + uses: "google-github-actions/auth@v2" |
| 23 | + with: |
| 24 | + credentials_json: ${{ secrets.GCP_SA_KEY }} |
25 | 25 |
|
26 |
| - - name: Docker를 위한 gcloud 인증 설정 |
27 |
| - run: gcloud auth configure-docker --quiet |
| 26 | + - name: Docker를 위한 gcloud 인증 설정 |
| 27 | + run: gcloud auth configure-docker --quiet |
28 | 28 |
|
29 |
| - - name: Create .env from secret |
30 |
| - run: | |
31 |
| - echo "${{ secrets.FE_ENV }}" > uniro_admin_frontend/.env |
| 29 | + - name: Create .env from secret |
| 30 | + run: | |
| 31 | + echo "${{ secrets.FE_ENV }}" > uniro_admin_frontend/.env |
32 | 32 |
|
33 |
| - - name: Docker 이미지 빌드 및 푸시 |
34 |
| - run: | |
35 |
| - docker build -t gcr.io/${{ env.GCP_PROJECT_ID }}/${{ env.IMAGE_NAME }}:${{ env.IMAGE_TAG }} -f uniro_admin_frontend/Dockerfile . |
36 |
| - docker push gcr.io/${{ env.GCP_PROJECT_ID }}/${{ env.IMAGE_NAME }}:${{ env.IMAGE_TAG }} |
| 33 | + - name: Docker 이미지 빌드 및 푸시 |
| 34 | + run: | |
| 35 | + docker build -t gcr.io/${{ env.GCP_PROJECT_ID }}/${{ env.IMAGE_NAME }}:${{ env.IMAGE_TAG }} -f uniro_admin_frontend/Dockerfile . |
| 36 | + docker push gcr.io/${{ env.GCP_PROJECT_ID }}/${{ env.IMAGE_NAME }}:${{ env.IMAGE_TAG }} |
37 | 37 |
|
38 |
| - CD: |
39 |
| - runs-on: ubuntu-latest |
40 |
| - needs: CI |
| 38 | + CD: |
| 39 | + runs-on: ubuntu-latest |
| 40 | + needs: CI |
41 | 41 |
|
42 |
| - env: |
43 |
| - GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} |
44 |
| - IMAGE_NAME: uniro-backoffice |
45 |
| - IMAGE_TAG: ${{ github.sha }} |
46 |
| - DEPLOY_PATH: ${{ secrets.DEPLOY_SERVER_PATH }} |
| 42 | + env: |
| 43 | + GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} |
| 44 | + IMAGE_NAME: uniro-backoffice |
| 45 | + IMAGE_TAG: ${{ github.sha }} |
| 46 | + DEPLOY_PATH: ${{ secrets.DEPLOY_SERVER_PATH }} |
47 | 47 |
|
48 |
| - steps: |
49 |
| - - name: 배포 서버에 SSH로 연결하여 배포 |
50 |
| - |
51 |
| - with: |
52 |
| - host: ${{ secrets.DEPLOY_SERVER_HOST }} |
53 |
| - username: ${{ secrets.DEPLOY_SERVER_USER }} |
54 |
| - key: ${{ secrets.DEPLOY_SSH_KEY }} |
55 |
| - envs: GCP_PROJECT_ID, IMAGE_NAME, IMAGE_TAG, DEPLOY_PATH, TEST |
56 |
| - script: | |
57 |
| - cd ${DEPLOY_PATH} |
58 |
| - sudo docker ps -a --format '{{.ID}} {{.Names}}' \ |
59 |
| - | egrep -v 'nginx-container|uniro-fe' \ |
60 |
| - | awk '{print $1}' \ |
61 |
| - | xargs -r sudo docker stop || true |
62 |
| - sudo docker rm $(sudo docker ps -a -q) || true |
63 |
| - sudo docker login -u _json_key --password-stdin https://gcr.io <<< '${{ secrets.GCP_SA_KEY }}' |
64 |
| - sudo docker pull gcr.io/${GCP_PROJECT_ID}/${IMAGE_NAME}:${IMAGE_TAG} |
65 |
| - sudo docker run -d --name ${IMAGE_NAME} -p 3001:3000 gcr.io/${GCP_PROJECT_ID}/${IMAGE_NAME}:${IMAGE_TAG} |
| 48 | + steps: |
| 49 | + - name: 배포 서버에 SSH로 연결하여 배포 |
| 50 | + |
| 51 | + with: |
| 52 | + host: ${{ secrets.DEPLOY_SERVER_HOST }} |
| 53 | + username: ${{ secrets.DEPLOY_SERVER_USER }} |
| 54 | + key: ${{ secrets.DEPLOY_SSH_KEY }} |
| 55 | + envs: GCP_PROJECT_ID, IMAGE_NAME, IMAGE_TAG, DEPLOY_PATH, TEST |
| 56 | + script: | |
| 57 | + cd ${DEPLOY_PATH} |
| 58 | + sudo docker ps -a --format '{{.ID}} {{.Names}}' \ |
| 59 | + | egrep -v 'nginx-container|uniro-fe' \ |
| 60 | + | awk '{print $1}' \ |
| 61 | + | xargs -r sudo docker stop || true |
| 62 | + sudo docker rm $(sudo docker ps -a -q) || true |
| 63 | + sudo docker login -u _json_key --password-stdin https://gcr.io <<< '${{ secrets.GCP_SA_KEY }}' |
| 64 | + sudo docker pull gcr.io/${GCP_PROJECT_ID}/${IMAGE_NAME}:${IMAGE_TAG} |
| 65 | + sudo docker run -d --name ${IMAGE_NAME} -p 3001:3000 gcr.io/${GCP_PROJECT_ID}/${IMAGE_NAME}:${IMAGE_TAG} |
| 66 | + sudo docker network connect nginx_app-network ${IMAGE_NAME} |
0 commit comments