-
Notifications
You must be signed in to change notification settings - Fork 1
75 lines (71 loc) · 2.34 KB
/
prod-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
name: Deploy and make release
on:
push:
tags:
- '*'
jobs:
deploy:
permissions:
contents: 'read'
id-token: 'write'
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
fetch-depth: 0
# Authenticate and setup SDK
- id: auth
uses: 'google-github-actions/auth@v1'
with:
workload_identity_provider: ${{ secrets.WORKLOAD_IDENTITY_PROVIDER }}
service_account: ${{ secrets.SERVICE_ACCOUNT }}
token_format: 'access_token'
- name: Set up Cloud SDK
uses: 'google-github-actions/setup-gcloud@v1'
- name: Get gcloud information
run: gcloud info
# Cloud Build + Cloud Run
- name: Extract tag name
id: tagname
run: echo "TAG_NAME=${GITHUB_REF/refs\/tags\//}" > $GITHUB_ENV
- name: Submit to Cloud Build
id: cloudbuild
run: |
gcloud builds submit --config deploy/gcp/cloudbuild.yml --substitutions=TAG_NAME=${{ env.TAG_NAME }}
echo "GCR_TAG=gcr.io/${{ secrets.PROJECT_ID }}/migas-server:${{ env.TAG_NAME }}" > $GITHUB_ENV
- name: Create environment file for Cloud Run
run: echo "${{ secrets.CLOUD_RUN_ENV_FILE }}" > .env
- name: Deploy to Cloud Run
id: cloudrun
run: |
gcloud run deploy migas-server \
--region=us-central1 \
--image=${{ env.GCR_TAG }} \
--platform=managed \
--min-instances=1 \
--max-instances=3 \
--ingress=all \
--allow-unauthenticated \
--set-cloudsql-instances=${{ secrets.SQL_INSTANCE_NAME }} \
--memory=512Mi \
--cpu=2 \
--args=--host,0.0.0.0,--port,8080,--proxy-headers,--header,X-Backend-Server:migas \
--cpu-throttling \
--env-vars-file=.env
- name: Cleanup env file
run: rm -f .env
release:
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/')
runs-on: ubuntu-latest
needs: deploy
permissions:
contents: write
steps:
- uses: actions/checkout@v3
with:
ref: ${{ github.ref }}
- name: Create GitHub release from annotated tag
uses: spenserblack/actions-tag-to-release@v1.1.0
with:
prerelease: auto
prerelease-pattern: '*rc*'