Skip to content

[๐Ÿ“ย docs]: DOCKER-CD.yml ํŠธ๋ฆฌ๊ฑฐ ์ˆ˜์ • #47

[๐Ÿ“ย docs]: DOCKER-CD.yml ํŠธ๋ฆฌ๊ฑฐ ์ˆ˜์ •

[๐Ÿ“ย docs]: DOCKER-CD.yml ํŠธ๋ฆฌ๊ฑฐ ์ˆ˜์ • #47

Workflow file for this run

name: DOCKER-CD
on:
push:
branches: [ "main" ]
jobs:
ci:
runs-on: ubuntu-24.04
env:
working-directory: .
steps:
- name: ์ฒดํฌ์•„์›ƒ
uses: actions/checkout@v3
- name: Set up JDK 21
uses: actions/setup-java@v3
with:
distribution: 'temurin'
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.YML_PROD }}" > ./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.DOCKER_LOGIN_USERNAME }}
password: ${{ secrets.DOCKER_LOGIN_ACCESSTOKEN }}
- name: docker image ๋นŒ๋“œ ๋ฐ ํ‘ธ์‹œ
run: |
docker build --platform linux/amd64 -t terningpoint/terning-deploy .
docker push terningpoint/terning-deploy
working-directory: ${{ env.working-directory }}
cd:
needs: ci
runs-on: ubuntu-24.04
steps:
- name: docker ์ปจํ…Œ์ด๋„ˆ ์‹คํ–‰
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.SERVER_IP }}
username: ${{ secrets.SERVER_USER }}
key: ${{ secrets.SERVER_KEY }}
script: |
cd ~
./deploy.sh