-
-
Notifications
You must be signed in to change notification settings - Fork 8
67 lines (53 loc) · 1.85 KB
/
build-deploy.yaml
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
name: Build & Deploy
on:
release:
types: [published]
jobs:
build:
name: Build
runs-on: ubuntu-latest
steps:
- name: Login to Registry
run: echo ${{ secrets.GITHUB_TOKEN }} | docker login ghcr.io -u ${{ github.actor }} --password-stdin
- name: Check out code into the Go module directory
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Build image
run: docker build -t ghcr.io/${GITHUB_REPOSITORY}:${GITHUB_REF#refs/tags/v} .
- name: Publish image
run: docker push --all-tags ghcr.io/${GITHUB_REPOSITORY}
- name: Logout
run: docker logout ghcr.io
deploy:
name: Deploy
runs-on: ubuntu-latest
needs: build
permissions:
contents: read
id-token: write
env:
NAMESPACE: production
DEPLOYMENT: rest-api-v2
CONTAINER: rest-api
steps:
- name: Check out
uses: actions/checkout@v4
- name: Authenticate to Google Cloud
uses: google-github-actions/auth@v2
with:
workload_identity_provider: '${{ secrets.GC_WORKLOAD_IDENTITY_PROVIDER }}'
service_account: '${{ secrets.GC_SERVICE_ACCOUNT }}'
- name: Get GKE cluster credentials
uses: google-github-actions/get-gke-credentials@v2
with:
cluster_name: '${{ secrets.GC_GKE_CLUSTER_NAME }}'
location: '${{ secrets.GC_GKE_CLUSTER_LOCATION }}'
- name: Deploy image
run: kubectl -n ${NAMESPACE} set image deployment/${DEPLOYMENT} ${CONTAINER}=ghcr.io/${GITHUB_REPOSITORY}:${GITHUB_REF#refs/tags/v}
- name: Check rollout
if: success()
run: kubectl -n ${NAMESPACE} rollout status deployment/${DEPLOYMENT} -w --timeout=5m
- name: Roll back
if: failure()
run: kubectl -n ${NAMESPACE} rollout undo deployment/${DEPLOYMENT}