-
Notifications
You must be signed in to change notification settings - Fork 0
97 lines (85 loc) Β· 3.29 KB
/
deploy-dev.yml
File metadata and controls
97 lines (85 loc) Β· 3.29 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
88
89
90
91
92
93
94
95
96
97
# ============================================================================
# Deploy to Azure Container Apps (develop)
# ============================================================================
# μν :
# - Integrate workflow μ±κ³΅ ν μλ μ€ν
# - GitHub Actionsμμ JAR λΉλ β ACRμ Docker μ΄λ―Έμ§ Push
# - Azure Container Appsμ μ μ΄λ―Έμ§ λ°°ν¬ (SSH μμ)
#
# GitHub Secrets:
# - AZURE_CREDENTIALS : Azure Service Principal JSON
#
# GitHub Variables (Settings > Variables > Actions):
# - ACR_NAME : ACR μ΄λ¦ (μ: dabom)
# - CONTAINER_APP_NAME : Container App μ΄λ¦ (μ: dabom-api-core)
# - RESOURCE_GROUP : 리μμ€ κ·Έλ£Ή μ΄λ¦ (μ: dabom-rg)
#
# νκ²½λ³μλ Container Appμ μ§μ μ€μ (Azure Portal λλ CLI)
# μ
μ
κ°μ΄λ: docs/azure-container-apps-setup.md
# ============================================================================
name: Deploy to Azure Container Apps
on:
workflow_run:
workflows: ["Integrate Backend"]
types:
- completed
branches:
- develop
workflow_dispatch:
env:
ACR_NAME: ${{ vars.ACR_NAME }}
CONTAINER_APP_NAME: ${{ vars.CONTAINER_APP_NAME }}
RESOURCE_GROUP: ${{ vars.RESOURCE_GROUP }}
jobs:
build-and-deploy:
name: Build & Deploy
runs-on: ubuntu-latest
if: false # Azure κ³μ μ’
λ£λ‘ λΉνμ±ν
steps:
# ββ 1. λΉλ ββ
- name: Checkout
uses: actions/checkout@v4
with:
ref: develop
- name: Set up Java 21
uses: actions/setup-java@v4
with:
java-version: '21'
distribution: 'temurin'
- name: Build JAR
run: |
chmod +x gradlew
./gradlew bootJar -x checkstyleMain -x checkstyleTest -x spotlessCheck --no-daemon
# ββ 2. ACRμ μ΄λ―Έμ§ Push ββ
- name: Azure Login
uses: azure/login@v2
with:
creds: ${{ secrets.AZURE_CREDENTIALS }}
- name: Login to ACR
run: az acr login --name ${{ env.ACR_NAME }}
- name: Build and Push Docker Image
run: |
REGISTRY=${{ env.ACR_NAME }}.azurecr.io
TAG=$REGISTRY/dabom-api-core:${{ github.sha }}
LATEST=$REGISTRY/dabom-api-core:latest
docker build -f Dockerfile.deploy -t $TAG -t $LATEST .
docker push $TAG
docker push $LATEST
# ββ 3. Container Apps λ°°ν¬ ββ
- name: Deploy to Container Apps
run: |
az containerapp update \
--name ${{ env.CONTAINER_APP_NAME }} \
--resource-group ${{ env.RESOURCE_GROUP }} \
--image ${{ env.ACR_NAME }}.azurecr.io/dabom-api-core:${{ github.sha }}
- name: Deployment Summary
run: |
FQDN=$(az containerapp show \
--name ${{ env.CONTAINER_APP_NAME }} \
--resource-group ${{ env.RESOURCE_GROUP }} \
--query properties.configuration.ingress.fqdn \
--output tsv)
echo "## Deployment Summary" >> $GITHUB_STEP_SUMMARY
echo "- **Image**: \`${{ env.ACR_NAME }}.azurecr.io/dabom-api-core:${{ github.sha }}\`" >> $GITHUB_STEP_SUMMARY
echo "- **URL**: https://$FQDN" >> $GITHUB_STEP_SUMMARY
echo "- **Triggered by**: ${{ github.event_name }}" >> $GITHUB_STEP_SUMMARY