Skip to content

deploy: 1.3.0 배포 #616 (#617) #39

deploy: 1.3.0 배포 #616 (#617)

deploy: 1.3.0 배포 #616 (#617) #39

name: Backend CI/CD prod
on:
push:
paths: [ 'backend/**', '.github/**' ]
branches: [ "release-be" ]
jobs:
ci:
runs-on: ubuntu-latest
defaults:
run:
shell: bash
working-directory: ./backend
permissions:
contents: read
steps:
- uses: actions/checkout@v4
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'temurin'
- name: Cache Gradle packages
uses: actions/cache@v3
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
key: gradle-${{ runner.os }}-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: |
gradle-${{ runner.os }}-
- name: Grant execute permission for gradlew
run: chmod +x gradlew
- name: Setup with Gradle
uses: gradle/actions/setup-gradle@417ae3ccd767c252f5661f1ace9f835f9654f2b5 # v3.1.0
- name: Build with Gradle
run: ./gradlew clean build
- name: Login to Docker Hub
uses: docker/[email protected]
with:
username: ${{ secrets.DOCKERHUB_DEPLOY_USERNAME }}
password: ${{ secrets.DOCKERHUB_DEPLOY_TOKEN }}
- name: Docker Image Build
run: |
sudo docker build --platform linux/arm64 -t staccato/staccato:prod -f Dockerfile.prod .
- name: Docker Hub Push
run: |
sudo docker login --username ${{ secrets.DOCKERHUB_DEPLOY_USERNAME }} --password ${{ secrets.DOCKERHUB_DEPLOY_TOKEN }}
sudo docker push staccato/staccato:prod
cd:
needs: ci
runs-on: [ self-hosted, prod ]
steps:
- name: execute deploy.sh
run: bash /home/ubuntu/staccato/deploy.sh