-
Notifications
You must be signed in to change notification settings - Fork 1
97 lines (80 loc) · 3.42 KB
/
nextjs-prod-CD.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
92
93
94
95
96
97
name: NextJS CD
on:
release:
types: [created]
push:
branches:
- MF-361-Next.js-CD-Github-Action
workflow_dispatch:
repository_dispatch:
env:
KCR_REGISTRY: dkation.kr-central-2.kcr.dev
KCR_REPOSITORY: dkation-prod-front/dkation-prod-fe
ACCESS_KEY: ${{ secrets.ACCESS_KEY }}
ACCESS_SECRET_KEY: ${{ secrets.ACCESS_SECRET_KEY }}
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Get release tag or commit hash
id: get_version
run: |
if [[ ${{ github.event_name }} == 'release' ]]; then
echo "version=${{ github.event.release.tag_name }}" >> $GITHUB_OUTPUT
else
git fetch --tags
latest_tag=$(git describe --tags --abbrev=0)
echo "version=$latest_tag" >> $GITHUB_OUTPUT
fi
- name: Deploy to FE
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.BASTION_IP }}
username: ${{ secrets.USER }}
key: ${{ secrets.SSH_KEY }}
script: |
mkdir -p ~/.ssh
echo "${{ secrets.SSH_KEY }}" > ~/.ssh/id_rsa
chmod 600 ~/.ssh/id_rsa
IFS=',' read -r -a HOSTS <<< "${{ secrets.WEB_IPS }}"
for host in "${HOSTS[@]}"
do
echo "Deploying to $host"
ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${{ secrets.USER }}@$host << 'EOF'
set -e
echo "Stopping and removing existing containers"
docker ps --format '{{.ID}} {{.Image}}' | grep 'dkation.kr-central-2.kcr.dev/dkation-prod-front/dkation-prod-fe' | awk '{print $1}' | xargs -r docker stop && \
docker ps -a --format '{{.ID}} {{.Image}}' | grep 'dkation.kr-central-2.kcr.dev/dkation-prod-front/dkation-prod-fe' | awk '{print $1}' | xargs -r docker rm && \
echo "Removing old Docker images"
docker images --format '{{.Repository}}:{{.Tag}}' | grep 'dkation.kr-central-2.kcr.dev/dkation-prod-front/dkation-prod-fe' | xargs -r docker rmi
echo "Login to KCR"
echo ${{ env.ACCESS_SECRET_KEY }} | docker login $KCR_REGISTRY --username ${{ env.ACCESS_KEY}} --password-stdin
echo "Pulling new Docker image"
docker pull $KCR_REGISTRY/$KCR_REPOSITORY:${{ steps.get_version.outputs.version }}
echo "Running new Docker container"
docker run -d -p 80:3000 --name dkation-frontend $KCR_REGISTRY/$KCR_REPOSITORY:${{ steps.get_version.outputs.version }}
echo "Checking container health"
max_retries=5
retries=0
until docker ps | grep frontend | grep -q "Up" || [ $retries -eq $max_retries ]
do
echo "Waiting for container to be healthy..."
sleep 5
retries=$((retries+1))
done
if [ $retries -eq $max_retries ]; then
echo "Container failed to start properly"
exit 1
fi
echo "Container is up and running"
if [ $? -ne 0 ]; then
echo "Deployment to $host failed"
exit 1
fi
echo "Deployment completed successfully"
EOF
done