From 5928b7f94e4085323c1b6d4ccaf5239e82003011 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=EC=88=98=ED=98=84?= <98441203+Oniqued@users.noreply.github.com> Date: Thu, 11 Jan 2024 02:05:27 +0900 Subject: [PATCH] =?UTF-8?q?chore=20:=20=EC=9E=90=EB=8F=99=20=EB=B0=B0?= =?UTF-8?q?=ED=8F=AC=20=EC=8A=A4=ED=81=AC=EB=A6=BD=ED=8A=B8=20=EC=9E=91?= =?UTF-8?q?=EC=84=B1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/friendship-pipeline.yml | 59 +++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 .github/workflows/friendship-pipeline.yml diff --git a/.github/workflows/friendship-pipeline.yml b/.github/workflows/friendship-pipeline.yml new file mode 100644 index 00000000..4b1e0680 --- /dev/null +++ b/.github/workflows/friendship-pipeline.yml @@ -0,0 +1,59 @@ +name: FriendShip - Deploy to Amazon EC2 + +on: + push: + branches: + - main + +env: + APP_NAME : friendship + BUILD_NAME : friendship + +permissions: + contents: read + +jobs: + build: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v3 + - name: Set up JDK 17 + uses: actions/setup-java@v3 + with: + java-version: '17' + distribution: 'temurin' + + # 설정 파일 추가 + - name: make application-prod.yml + run: | + cd ./src/main/resources + touch ./application-prod.yml + echo "${{ secrets.APPLICATION_PROD }}" > ./application-prod.yml + + - name: Grant execute permission for gradlew + run: chmod +x gradlew + + - name: Build with Gradle + run: ./gradlew build -x test + + - name: Docker build + run: | + docker login -u ${{ secrets.DOCKER_USERNAME }} -p ${{ secrets.DOCKER_PASSWORD }} + docker build --platform linux/arm64/v8 -t app . + docker tag app ${{ secrets.DOCKER_USERNAME }}/${{ env.APP_NAME }}:latest + docker push ${{ secrets.DOCKER_USERNAME }}/${{ env.APP_NAME }}:latest + + - name: Deploy + uses: appleboy/ssh-action@master + with: + host: ${{ secrets.HOST }} # EC2 인스턴스 퍼블릭 DNS + username: ec2-user + key: ${{ secrets.PRIVATE_KEY }} # pem 키 + # 도커 작업 + script: | + sudo docker pull ${{ secrets.DOCKER_USERNAME }}/${{ env.APP_NAME }}:latest + sudo docker stop $(docker ps -a -q) + sudo docker run -d --log-driver=syslog -p 8080:8080 ${{ secrets.DOCKER_USERNAME }}/${{ env.APP_NAME }} + sudo docker rm $(docker ps --filter 'status=exited' -a -q) + sudo docker image prune -a -f