-
Notifications
You must be signed in to change notification settings - Fork 2
116 lines (101 loc) · 4.21 KB
/
record-deploy.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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
name: Record Server Ci/Cd
on:
push:
branches:
- develop
- Fix/326
paths:
- 'apps/record/**'
jobs:
build-and-push:
runs-on: ubuntu-latest
env:
IMAGE_NAME: record-camon
RECORD_PORT: ${{ secrets.RECORD_PORT }}
NCLOUD_ACCESS_KEY: ${{ secrets.NCLOUD_ACCESS_KEY }}
NCLOUD_SECRET_KEY: ${{ secrets.NCLOUD_SECRET_KEY }}
NCLOUD_BUCKET_NAME: ${{ secrets.NCLOUD_BUCKET_NAME }}
API_SERVER_URL: ${{ secrets.API_SERVER_URL }}
CDN_URL: ${{ secrets.CDN_URL }}
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Log in to Ncloud Container Registry
env:
USERNAME: ${{ secrets.NCLOUD_ACCESS_KEY }}
PASSWORD: ${{ secrets.NCLOUD_SECRET_KEY }}
REGISTRY_URL: ${{ secrets.NCLOUD_REGISTRY_URL }}
run: |
echo "$PASSWORD" | docker login -u "$USERNAME" "$REGISTRY_URL" --password-stdin
- name: Build Docker image
run: |
docker build -f ./apps/record/Dockerfile -t ${{ secrets.NCLOUD_REGISTRY_URL }}/$IMAGE_NAME:latest \
--build-arg RECORD_PORT=$RECORD_PORT \
--build-arg NCLOUD_ACCESS_KEY=$NCLOUD_ACCESS_KEY \
--build-arg NCLOUD_SECRET_KEY=$NCLOUD_SECRET_KEY \
--build-arg NCLOUD_BUCKET_NAME=$NCLOUD_BUCKET_NAME \
--build-arg API_SERVER_URL=$API_SERVER_URL \
--build-arg CDN_URL=$CDN_URL \
.
- name: Push to Ncloud Container Registry
run: |
docker push ${{ secrets.NCLOUD_REGISTRY_URL }}/$IMAGE_NAME:latest
deploy-and-run:
runs-on: ubuntu-latest
needs: build-and-push
env:
IMAGE_NAME: record-camon
RECORD_PORT: ${{ secrets.RECORD_PORT }}
NCLOUD_ACCESS_KEY: ${{ secrets.NCLOUD_ACCESS_KEY }}
NCLOUD_SECRET_KEY: ${{ secrets.NCLOUD_SECRET_KEY }}
NCLOUD_BUCKET_NAME: ${{ secrets.NCLOUD_BUCKET_NAME }}
NCLOUD_REGISTRY_URL: ${{ secrets.NCLOUD_REGISTRY_URL }}
API_SERVER_URL: ${{ secrets.API_SERVER_URL }}
CDN_URL: ${{ secrets.CDN_URL }}
steps:
- name: Checkout for docker-compose
uses: actions/checkout@v2
- name: Copy docker-compose file
uses: appleboy/scp-action@master
with:
host: ${{ secrets.SERVER_IP }}
username: ${{ secrets.SERVER_USER }}
key: ${{ secrets.SSH_SERVER_KEY }}
source: "docker-compose.yml"
target: "/home/${{ secrets.SERVER_USER }}/camon"
- name: SSH and deploy
uses: appleboy/[email protected]
with:
host: ${{ secrets.SERVER_IP }}
username: ${{ secrets.SERVER_USER }}
key: ${{ secrets.SSH_SERVER_KEY }}
port: 22
envs: RECORD_PORT,NCLOUD_ACCESS_KEY,NCLOUD_SECRET_KEY,NCLOUD_BUCKET_NAME,NCLOUD_REGISTRY_URL,API_SERVER_URL,CDN_URL
script: |
cd /home/${{ secrets.SERVER_USER }}/camon
echo "RECORD_PORT=$RECORD_PORT" > .env
echo "NCLOUD_ACCESS_KEY=$NCLOUD_ACCESS_KEY" >> .env
echo "NCLOUD_SECRET_KEY=$NCLOUD_SECRET_KEY" >> .env
echo "NCLOUD_BUCKET_NAME=$NCLOUD_BUCKET_NAME" >> .env
echo "NCLOUD_REGISTRY_URL=$NCLOUD_REGISTRY_URL" >> .env
echo "API_SERVER_URL=$API_SERVER_URL" >> .env
echo "CDN_URL=$CDN_URL" >> .env
sudo docker login -u $NCLOUD_ACCESS_KEY -p $NCLOUD_SECRET_KEY $NCLOUD_REGISTRY_URL
sudo docker stop record-camon || true
sudo docker rm record-camon || true
sudo docker rmi $NCLOUD_REGISTRY_URL/record-camon:latest || true
sudo docker pull $NCLOUD_REGISTRY_URL/record-camon:latest
sudo docker tag $NCLOUD_REGISTRY_URL/record-camon:latest record-camon
sudo docker-compose up -d record
sudo docker image prune -f
- name: Check container status
uses: appleboy/[email protected]
with:
host: ${{ secrets.SERVER_IP }}
username: ${{ secrets.SERVER_USER }}
key: ${{ secrets.SSH_SERVER_KEY }}
port: 22
script: |
cd /home/${{ secrets.SERVER_USER }}/camon
sudo docker-compose ps record
sudo docker-compose logs --tail=100 record