chore(.gitignore) : .gitignore 파일 작성 #5
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: DOCKER-CD-PROD | |
on: | |
push: | |
branches: [ "main" ] | |
jobs: | |
ci: | |
# Using Environment - prod 환경 사용 | |
# environment: prod | |
runs-on: ubuntu-24.04 | |
env: | |
working-directory: . | |
# Checkout - 가상 머신에 체크아웃 | |
steps: | |
- name: 체크아웃 | |
uses: actions/checkout@v3 | |
# JDK setting - Amazon Corretto JDK 21 설정 | |
- name: Set up Amazon Corretto JDK 21 | |
uses: actions/setup-java@v3 | |
with: | |
distribution: 'corretto' | |
java-version: '21' | |
# Gradle caching - 빌드 시간 향상 | |
- name: Gradle Caching | |
uses: actions/cache@v3 | |
with: | |
path: | | |
~/.gradle/caches | |
~/.gradle/wrapper | |
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }} | |
restore-keys: | | |
${{ runner.os }}-gradle- | |
- name: application.yml 생성 | |
run: | | |
mkdir -p ./src/main/resources && cd $_ | |
touch ./application.yml | |
echo "${{ secrets.YML }}" > ./application.yml | |
cat ./application.yml | |
working-directory: ${{ env.working-directory }} | |
- name: application-prod.yml 생성 | |
run: | | |
cd ./src/main/resources | |
touch ./application-prod.yml | |
echo "${{ secrets.PROD_YML }}" > ./application-prod.yml | |
working-directory: ${{ env.working-directory }} | |
- name: 빌드 | |
run: | | |
chmod +x gradlew | |
./gradlew build -x test | |
working-directory: ${{ env.working-directory }} | |
shell: bash | |
- name: docker 로그인 | |
uses: docker/[email protected] | |
- name: login docker hub | |
uses: docker/[email protected] | |
with: | |
username: ${{ secrets.PROD_DOCKER_LOGIN_USERNAME }} | |
password: ${{ secrets.PROD_DOCKER_LOGIN_ACCESSTOKEN }} | |
- name: docker image 빌드 및 푸시 | |
run: | | |
docker build -f Dockerfile-prod --platform linux/amd64 -t noostak/server . | |
docker push noostak/server | |
working-directory: ${{ env.working-directory }} | |
cd: | |
needs: ci | |
runs-on: ubuntu-24.04 | |
steps: | |
- name: docker 컨테이너 실행 | |
uses: appleboy/ssh-action@master | |
with: | |
host: ${{ secrets.PROD_SERVER_IP }} | |
username: ${{ secrets.PROD_SERVER_USER }} | |
key: ${{ secrets.PROD_SERVER_KEY }} | |
script: | | |
cd ~ | |
./deploy-prod.sh |