Skip to content

Commit

Permalink
chore: GitHub Action Workflow 생성
Browse files Browse the repository at this point in the history
- 빌드 작업과 배포 작업을 분리
- 기존 workflow 빌드, 배포 업무 개선
  • Loading branch information
ddackkeun committed Jul 20, 2024
1 parent 00ab1e7 commit 75decea
Showing 1 changed file with 87 additions and 0 deletions.
87 changes: 87 additions & 0 deletions .github/workflows/photosmap-ci-cd.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
name: PhotosMap CI/CD Workflow

on:
push:
branches: [ "develop" ]
pull_request:
branches: [ "develop" ]

permissions:
contents: read

jobs:
build:
runs-on: ubuntu-latest

steps:
- name: Checkout repository
uses: actions/checkout@v2

- name: Create application-base-addi.yml
run: echo "${{ secrets.BASE_ADDI }}" > ./src/main/resources/application-base-addi.yml

- name: Verify application-base-addi.yml
run: ls -la ./src/main/resources/

- name: Set up JDK 17
uses: actions/setup-java@v2
with:
distribution: 'adopt'
java-version: '17'

- name: Grant execute permission for gradlew
run: chmod +x ./gradlew

- name: Build with Gradle
run: ./gradlew bootJar

- name: Login to DockerHub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_PASSWORD }}

- name: Build Docker image
run: docker build -t ${{ secrets.DOCKERHUB_USERNAME }}/photosmap:latest --build-arg PROFILES=prod .

- name: Push Docker image to Docker Hub
run: docker push ${{ secrets.DOCKERHUB_USERNAME }}/photosmap:latest

deploy:
runs-on: ubuntu-latest
needs: build

steps:
- name: Checkout repository
uses: actions/checkout@v2

- name: Set up SSH
uses: webfactory/[email protected]
with:
ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }}

- name: Create docker-compose-prod.yml
run: echo "${{ secrets.DOCKER_COMPOSE_PROD }}" > ./docker-compose-prod.yml

- name: Verify docker-compose-prod.yml
run: ls -la ./

- name: Set file permissions for application-base-addi.yml
run: chmod 644 ./src/main/resources/application-base-addi.yml

- name: Copy files to EC2
run: |
scp -P ${{ secrets.SSH_PORT }} -o StrictHostKeyChecking=no ./docker-compose-prod.yml ${{ secrets.SSH_USER }}@${{ secrets.EC2_HOST }}:${{ secrets.EC2_PATH }}/
scp -P ${{ secrets.SSH_PORT }} -o StrictHostKeyChecking=no ./src/main/resources/application-base-addi.yml ${{ secrets.SSH_USER }}@${{ secrets.EC2_HOST }}:${{ secrets.EC2_PATH }}/
- name: Deploy on EC2
run: |
ssh -p ${{ secrets.SSH_PORT }} -o StrictHostKeyChecking=no ${{ secrets.SSH_USER }}@${{ secrets.EC2_HOST }} << 'EOF'
docker login -u ${DOCKER_USERNAME} -p ${DOCKER_PASSWORD}
docker pull ${{ secrets.DOCKERHUB_USERNAME }}/photosmap:latest
docker-compose -f ${{ secrets.EC2_PATH }}/docker-compose-prod.yml down
docker-compose -f ${{ secrets.EC2_PATH }}/docker-compose-prod.yml up -d
EOF
env:
DOCKER_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }}
DOCKER_PASSWORD: ${{ secrets.DOCKERHUB_PASSWORD }}

0 comments on commit 75decea

Please sign in to comment.