Merge pull request #132 from yooonwodyd/weekly #49
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: Java CICD | |
on: | |
workflow_dispatch: | |
push: | |
branches: | |
- 'Master' | |
jobs: | |
ci-pipeline: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Set up JDK 21 | |
uses: actions/setup-java@v4 | |
with: | |
distribution: 'adopt' | |
java-version: '21' | |
- name: Create application.yaml | |
run: | | |
mkdir -p src/main/resources | |
echo '${{ secrets.APPLICATION_YAML }}' > src/main/resources/application.yaml | |
cat src/main/resources/application.yaml | |
shell: bash | |
- name: Grant execute permission for Gradle Wrapper | |
run: chmod +x ./gradlew | |
- name: Build with Gradle | |
run: ./gradlew clean build -x test | |
# - name: Test with Gradle | |
# run: ./gradlew test | |
# 경로 확인 | |
- name: Verify JAR file | |
run: ls build/libs/*.jar | |
# Docker 로그인 | |
- name: Docker Login | |
uses: docker/[email protected] | |
with: # 도커 로그인에 필요한 입력값 | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
# 위 과정을 통해 후속 단계에서 이미지를 푸시할 수 있는 권한 얻음 | |
# Docker 이미지 빌드 및 푸시 | |
- name: image build and push docker images | |
uses: docker/[email protected] | |
with: | |
context: . # 빌드할 도커 파일이 있는 디렉토리 | |
push: true # 이미지 빌드 후 Docker Hub 에 이미지 푸시 여부 | |
tags: ${{ secrets.DOCKER_USERNAME }}/katecam-backend:latest # Docker Hub 사용자 이름, 리포지토리 이름, 빌드된 이미지에 붙일 태그 | |
no-cache: true # 이미지 빌드 시 캐시 사용 여부 | |
# EC2 인스턴스에 Docker 이미지 배포 | |
- name: Deploy to AWS EC2 | |
uses: appleboy/[email protected] | |
with: | |
host: ${{ secrets.AWS_HOST_IP }} # 인스턴스 IP | |
username: ${{ secrets.REMOTE_USER }} # 우분투 ID | |
key: ${{ secrets.AWS_EC2_PRIVATE_KEY }} # EC2 인스턴스 pem key | |
port: ${{ secrets.REMOTE_SSH_PORT }} # 접속 포트(생략 시 22번 기본 사용) | |
script: | | |
cd /home/ubuntu # EC2 인스턴스의 배포 스크립트 파일 경로로 이동 | |
chmod +x deploy.sh # 배포 스크립트 실행 권한 부여 | |
./deploy.sh # 배포 스크립트 실행 |