forked from Bumblebee-Bee/Room-it_BE
-
Notifications
You must be signed in to change notification settings - Fork 0
87 lines (73 loc) ยท 3.34 KB
/
CI-CD.yml
File metadata and controls
87 lines (73 loc) ยท 3.34 KB
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
name: CI/CD
on:
push:
branches: [ release ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
# Docker Compose ์ค์น
- name: Install Docker Compose
run: |
sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
# Docker Compose ๋ฒ์ ํ์ธ
- name: Check Docker Compose version
run: docker-compose --version
# main/resources์ ๊ธฐ๋ณธ ํ๋กํผํฐ ํ์ผ ์์ฑ
- run: |
mkdir -p ./src/main/resources
touch ./src/main/resources/application.properties # ํ์ผ ์์ฑ
echo "${{ secrets.APPLICATION_PROPERTIES }}" > ./src/main/resources/application.properties # ํ์ผ์ ๋ด์ฉ ์ถ๊ฐ
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: 17
distribution: 'temurin'
# gradlew ์คํ ๊ถํ ๋ถ์ฌ
- name: Grant execute permission for gradlew
run: chmod +x gradlew
# Gradle ๋น๋
- name: Build with Gradle
run: ./gradlew clean bootJar -x test
# ํ์ฌ ์๊ฐ ์ ๋ณด ๊ฐ์ ธ์ค๊ธฐ
- name: Get current time
uses: josStorer/get-current-time@v2
id: current-time
with:
format: YYYY-MM-DDTHH-mm-ss
utcOffset: "+09:00"
# ๋น๋๋ JAR ํ์ผ ๊ฒฝ๋ก ์ค์
- name: Set artifact path
run: |
artifact=$(ls ./build/libs/WEB1_2_BUMBLEBEE_BE-*.jar | head -n 1)
artifact=${artifact//\"/} # Remove any double quotes from the artifact path
echo "artifact=$artifact" >> $GITHUB_ENV
# EC2 SSH ํค๋ฅผ ํ์ผ๋ก ์ ์ฅ
- name: Save SSH key
run: |
echo "${{ secrets.EC2_SSH_KEY }}" > /tmp/ssh-key.pem
chmod 600 /tmp/ssh-key.pem
# EC2์์ Docker ๋๋ ํ ๋ฆฌ ๊ถํ ์ค์ (ํ์ผ ๋ณต์ฌ ์ )
- name: Set Docker directory permissions on EC2
run: |
ssh -i /tmp/ssh-key.pem -o StrictHostKeyChecking=no ec2-user@${{ secrets.EC2_PUBLIC_IP }} "sudo mkdir -p /Docker"
ssh -i /tmp/ssh-key.pem -o StrictHostKeyChecking=no ec2-user@${{ secrets.EC2_PUBLIC_IP }} "sudo chown -R ec2-user:ec2-user /Docker"
ssh -i /tmp/ssh-key.pem -o StrictHostKeyChecking=no ec2-user@${{ secrets.EC2_PUBLIC_IP }} "sudo chmod -R 777 /Docker"
# EC2์ ํ์ผ ๋ณต์ฌ (docker-compose.yml๊ณผ python-server ๋๋ ํ ๋ฆฌ)
- name: Copy docker-compose.yml and python-server to EC2
run: |
# python-server ๋๋ ํ ๋ฆฌ ๋ณต์ฌ (-r ์ต์
์ ์ฌ์ฉํ์ฌ ๋๋ ํ ๋ฆฌ ๋ณต์ฌ)
scp -i /tmp/ssh-key.pem -o StrictHostKeyChecking=no -r ./python-server ec2-user@${{ secrets.EC2_PUBLIC_IP }}:/Docker/
# Elastic Beanstalk ๋ฐฐํฌ
- name: Beanstalk Deploy
uses: einaregilsson/beanstalk-deploy@v20
with:
aws_access_key: ${{ secrets.AWS_ACCESS_KEY }}
aws_secret_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
application_name: bumblebee-final
environment_name: Bumblebee-final-env
version_label: github-action-${{ steps.current-time.outputs.formattedTime }}
region: ap-northeast-2
deployment_package: ${{ env.artifact }} # JAR ํ์ผ ๊ฒฝ๋ก๋ฅผ ํ๊ฒฝ ๋ณ์๋ก ์ ๋ฌ