diff --git a/.github/workflows/build-docker-image-prd.yml b/.github/workflows/build-docker-image-prd.yml new file mode 100644 index 00000000..ba38f0be --- /dev/null +++ b/.github/workflows/build-docker-image-prd.yml @@ -0,0 +1,37 @@ +name: Build Backend Image Prd + +on: + workflow_call: + secrets: + DOCKERHUB_USERNAME: + required: true + DOCKERHUB_PASSWORD: + required: true + PRD_DOCKER_BATTLE_IMAGE_NAME: + required: true + +jobs: + build: + runs-on: ubuntu-latest + + steps: + - name: Checkout + uses: actions/checkout@v3 + + - name: Set up JDK 17 + uses: actions/setup-java@v1 + with: + java-version: '17' + distribution: 'temurin' + + - name: Login to Docker Hub + uses: docker/login-action@v2.1.0 + with: + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_PASSWORD }} + + - name: Grant execute permission for gradlew + run: chmod +x ./gradlew + + - name: Build with jib + run: ./gradlew jib --image="${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.PRD_DOCKER_BATTLE_IMAGE_NAME }}" diff --git a/.github/workflows/cd-prd.yml b/.github/workflows/cd-prd.yml new file mode 100644 index 00000000..46ba6fd1 --- /dev/null +++ b/.github/workflows/cd-prd.yml @@ -0,0 +1,32 @@ +name : cd - prd + +on: + push: + branches: + - main + +jobs: + build-back-docker-img: + uses: ./.github/workflows/build-docker-image-prd.yml + secrets: + DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }} + DOCKERHUB_PASSWORD: ${{ secrets.DOCKERHUB_PASSWORD }} + PRD_DOCKER_BATTLE_IMAGE_NAME: ${{ secrets.PRD_DOCKER_BATTLE_IMAGE_NAME }} + + deploy: + needs: build-back-docker-img + runs-on: ubuntu-latest + steps: + - name: executing remote ssh commands using password + uses: appleboy/ssh-action@master + with: + host: ${{ secrets.PRD_HOST }} + username: ${{ secrets.PRD_HOST_USER_NAME }} + key: ${{ secrets.PRD_PRIVATE_KEY }} + script: | + cd ${{ secrets.PRD_DEPLOY_DIRECTORY }} + docker compose stop ${{ secrets.PRD_DOCKER_BATTLE_CONTAINER_NAME }} + docker compose rm -f ${{ secrets.PRD_DOCKER_BATTLE_CONTAINER_NAME }} + docker image rm ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.PRD_DOCKER_BATTLE_IMAGE_NAME }} + docker pull ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.PRD_DOCKER_BATTLE_IMAGE_NAME }} + docker compose up -d