-
Notifications
You must be signed in to change notification settings - Fork 0
91 lines (79 loc) · 2.72 KB
/
work.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
name: 'work'
on:
push:
branches:
- 'main'
jobs:
update:
name: 프로젝트 버전 업데이트
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Set up JDK 17
uses: actions/setup-java@v2
with:
java-version: '17'
distribution: 'adopt'
build:
name: 이미지 빌드 및 도커허브 푸시
runs-on: ubuntu-latest
needs: update
steps:
- uses: actions/checkout@v3
with:
ref: refs/heads/main
- name: application-prod.yml 생성
env:
ACTIONS_STEP_DEBUG: true
APPLICATION_PROD: ${{ secrets.APPLICATION_PROD_YML }}
run: echo "$APPLICATION_PROD" > src/main/resources/application-prod.yml
- name: application-secret.yml 생성
env:
ACTIONS_STEP_DEBUG: true
APPLICATION_SECRET: ${{ secrets.APPLICATION_SECRET_YML }}
run: echo "$APPLICATION_SECRET" > src/main/resources/application-secret.yml
- name: 테스트용 redis docker로 띄우기
run: |
docker run --name redis -d -p 6379:6379 redis:latest
- name: jdk 17 설치
uses: actions/setup-java@v3
with:
java-version: '17'
distribution: 'temurin'
cache: 'gradle'
- name: gradlew 실행 권한 부여
run: chmod +x gradlew
- name: gradle 빌드
run: ./gradlew build --no-daemon -i
- name: build 폴더를 캐시에 저장
uses: actions/upload-artifact@v3
with:
name: build-artifact
path: build
retention-days: 1
- name: 도커 이미지 빌드 및 푸시
run: |
docker login -u ${{ secrets.DOCKER_HUB_USERNAME }} -p ${{ secrets.DOCKER_HUB_PASSWORD }}
docker build -t ${{ secrets.DOCKER_REPO }}/farming .
docker push ${{ secrets.DOCKER_REPO }}/farming
deploy:
name: 원격 서버에 배포
runs-on: ubuntu-latest
needs: build
steps:
- name: 원격 서버에 배포하기
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USER }}
key: ${{ secrets.SSH_KEY }}
port: 22
script: |
sudo docker login -u ${{ secrets.DOCKER_HUB_USERNAME }} -p ${{ secrets.DOCKER_HUB_PASSWORD }}
sudo docker stop farming_app || true
sudo docker rm farming_app || true
sudo docker pull ${{ secrets.DOCKER_REPO }}/farming
sudo docker run --name=farming_app --restart unless-stopped \
-p 8080:8080 -e TZ=Asia/Seoul -d ${{ secrets.DOCKER_REPO }}/farming
sudo docker image prune -f