Update deploy.yml #14
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: Spring Boot & Gradle CI/CD | |
| on: | |
| push: | |
| branches: | |
| - develop | |
| pull_request: | |
| branches: | |
| - develop | |
| permissions: | |
| contents: read | |
| jobs: | |
| build: | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v3 | |
| # JDK 17 설치 | |
| - name: Set up JDK 17 | |
| uses: actions/setup-java@v3 | |
| with: | |
| java-version: '17' | |
| distribution: 'temurin' | |
| - name: make application.yml | |
| run: | | |
| cd ./src/main/resources | |
| touch ./application-dev.yml | |
| echo "${{ secrets.APPLICATION_DEV_YML }}" >> ./application-dev.yml | |
| shell: bash | |
| # gradlew에 실행 권한을 부여합니다. | |
| - name: Grant execute permission for gradlew | |
| run: chmod +x gradlew | |
| # test는 CI 과정에서 수행되므로 여기서는 `-x`로 테스트를 생략했습니다. | |
| # `--stacktrace`로 더 자세한 로그가 출력되게 해줍니다. | |
| - name: Build with Gradle (without Test) | |
| run: ./gradlew clean build -x test --stacktrace | |
| # docker hub에 로그인하고 이미지를 빌드합니다. 이후에 push를 진행합니다. | |
| # docker_username을 적지 않으면 push 시에 요청이 거부될 수 있습니다. | |
| - name: Docker Hub build & push | |
| run: | | |
| docker login -u ${{ secrets.DOCKER_USERNAME }} -p ${{ secrets.DOCKER_PASSWORD }} | |
| docker build -t ${{ secrets.DOCKER_USERNAME }}/${{ secrets.DOCKER_REPO }} . | |
| docker push ${{ secrets.DOCKER_USERNAME }}/${{ secrets.DOCKER_REPO }} | |
| # EC2에 접속하고 배포합니다. | |
| - name: Deploy | |
| uses: appleboy/ssh-action@master | |
| with: | |
| host: ${{ secrets.EC2_HOST }} | |
| username: ${{ secrets.EC2_USERNAME }} | |
| key: ${{ secrets.EC2_PRIVATE_KEY }} | |
| script: | | |
| cd /home/ubuntu/CatchMate-SpringBoot | |
| sudo docker login -u ${{ secrets.DOCKER_USERNAME }} -p ${{ secrets.DOCKER_PASSWORD }} | |
| sudo docker rm -f $(sudo docker ps -qa) | |
| sudo docker pull ${{ secrets.DOCKER_USERNAME }}/${{ secrets.DOCKER_REPO }} | |
| sudo docker-compose up -d | |
| sudo docker image prune -f |