Skip to content

[Feat]: 도커파일 layeredjar 적용 #94

[Feat]: 도커파일 layeredjar 적용

[Feat]: 도커파일 layeredjar 적용 #94

Workflow file for this run

name: Build & Deploy
on:
push:
branches: [ "main" ] # main 브랜치에 push가 발생하면 workflow가 실행됩니다.
permissions:
contents: read # 권한을 설정합니다.
jobs:
ci:
runs-on: ubuntu-latest
# set up java
steps:
- name: Checkout Repository # 저장소를 체크아웃합니다.
uses: actions/checkout@v4
- name: Set up JDK 17 # JDK 17을 설정합니다.
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'adopt'
- name: Setup Gradle And Build # Gradle을 설정하고 빌드합니다.
run: |
chmod +x ./gradlew
./gradlew clean build
java -Djarmode=layertools -jar zzansuni-api-server/app/build/libs/app-0.0.1-SNAPSHOT.jar extract
- name: Set up Docker Buildx # Docker Buildx를 설정합니다.
uses: docker/setup-buildx-action@v3
- name: Login to Docker Hub # Docker Hub에 로그인합니다.
uses: : docker/login-action@v3

Check failure on line 35 in .github/workflows/cicd.yml

View workflow run for this annotation

GitHub Actions / .github/workflows/cicd.yml

Invalid workflow file

You have an error in your yaml syntax on line 35
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push Docker image # Docker 이미지를 빌드하고 푸시합니다.
uses: docker/build-push-action@v6
with:
context: .
push: true
tags: ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKER_REPOSITORY }}:${{ github.sha }}
cache-from: type=gha # GitHub Actions 캐시를 사용합니다.
cache-to: type=gha,mode=max
cd:
runs-on: ubuntu-latest # ubuntu 최신 버전에서 script를 실행
needs: ci # ci job이 성공적으로 끝나야 cd job이 실행됩니다.
# appleboy/ssh-action@master 액션을 사용하여 지정한 서버에 ssh로 접속하고, script를 실행합니다.
# script의 내용은 도커의 기존 프로세스들을 제거하고, docker repo로부터 방금 위에서 push한 내용을 pull 받아 실행하는 것입니다.
steps:
- name: Deploy to server
uses: appleboy/ssh-action@master
id: deploy
with:
host: ${{ secrets.HOST }}
username: ubuntu
key: ${{ secrets.KEY }}
port: 22
script: |
docker rm -f $(docker ps -qa --filter "name=zzansuni-spring") # 기존 zzansuni-spring 서버만 잡아서 중지합니다.
# 기존에 사용되던 spring 이미지만 제거합니다.
docker rmi $(docker images -q --filter "reference=${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKER_REPOSITORY }}")
docker image prune -f # 사용하지 않는 도커 이미지들을 제거합니다.
docker pull ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKER_REPOSITORY }}:${{ github.sha }}
docker run -d -p 8080:8080 -e SPRING_PROFILES_ACTIVE=prod \
--name zzansuni-spring \
-e KAKAO_CLIENT_SECRET=${{ secrets.KAKAO_CLIENT_SECRET }} \
-e NAVER_CLIENT_SECRET=${{ secrets.NAVER_CLIENT_SECRET }} \
-e KAKAO_REDIRECT_URI=${{ secrets.KAKAO_REDIRECT_URI }} \
-e MYSQL_URL=${{ secrets.MYSQL_URL }} \
-e MYSQL_USERNAME=${{ secrets.MYSQL_USERNAME }} \
-e MYSQL_PASSWORD=${{ secrets.MYSQL_PASSWORD }} \
-e S3_BUCKET=${{ secrets.S3_BUCKET }} \
-e S3_ACCESS_KEY=${{ secrets.S3_ACCESS_KEY }} \
-e S3_SECRET_KEY=${{ secrets.S3_SECRET_KEY }} \
${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKER_REPOSITORY }}:${{ github.sha }}