chore(friendship-pipeline) : 이전 버전의 이미지만 제거하도록 파이프라인 변경 #48
This file contains 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: 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: JDK 17 설치 | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '17' | |
distribution: 'temurin' | |
# 설정 파일 추가 | |
- name: application-secret.yml 구성 | |
run: | | |
cd ./src/main/resources | |
touch ./application-secret.yml | |
echo "${{ secrets.APPLICATION_SECRET }}" > ./application-secret.yml | |
- name: firebase_service_key.json 구성 | |
run: | | |
cd ./src/main/resources | |
touch ./firebase_service_key.json | |
echo "${{ secrets.FCM_KEY }}" > ./firebase_service_key.json | |
- name: firebase_service_key.json 파일 생성 | |
id: create-json | |
uses: jsdaniell/[email protected] | |
with: | |
name: "firebase_service_key.json" | |
json: ${{ secrets.FCM_KEY }} | |
- name: JSON 파일 이동 | |
run: | | |
mv ./firebase_service_key.json ./src/main/resources/firebase_service_key.json | |
- name: gradlew 실행 권한 부여 | |
run: chmod +x gradlew | |
- name : asciidoc 플러그인 실행 및 생성된 html 파일 정적 저장소로 이동 | |
run: | | |
./gradlew asciidoctor | |
mkdir -p src/main/resources/static/docs | |
cp -r build/docs/asciidoc/* src/main/resources/static/docs/ | |
- name: Gradle 빌드 | |
run: ./gradlew build -x test | |
- name: Docker 이미지 파일 PUSH | |
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: AWS 배포 | |
uses: appleboy/ssh-action@master | |
with: | |
host: ${{ secrets.HOST }} # EC2 인스턴스 퍼블릭 DNS | |
username: ec2-user | |
key: ${{ secrets.PRIVATE_KEY }} # pem 키 | |
# 도커 작업 | |
script: | | |
# 최신 friendship 이미지를 pull | |
sudo docker pull ${{ secrets.DOCKER_USERNAME }}/${{ env.APP_NAME }}:latest | |
# 현재 실행 중인 friendship 컨테이너 중지 및 제거 | |
sudo docker stop $(docker ps --filter "ancestor=${{ secrets.DOCKER_USERNAME }}/${{ env.APP_NAME }}" -q) | |
sudo docker rm $(docker ps --filter "ancestor=${{ secrets.DOCKER_USERNAME }}/${{ env.APP_NAME }}" -a -q) | |
# 새로운 friendship 컨테이너 실행 | |
sudo docker run -d --log-driver=syslog -p 443:8080 -e TZ=Asia/Seoul ${{ secrets.DOCKER_USERNAME }}/${{ env.APP_NAME }}:latest | |
# latest를 제외한 friendship 이미지만 삭제 | |
images=$(docker images --filter "reference=${{ secrets.DOCKER_USERNAME }}/${{ env.APP_NAME }}" --format "{{.Repository}}:{{.Tag}}" | grep -v 'latest') | |
if [ ! -z "$images" ]; then | |
docker rmi $images | |
fi |