Files
invyone/.gitea/workflows/deploy.yml
T
johngreen 6965dfdd57
Build & Deploy to K8s / build-and-deploy (push) Failing after 3m22s
ci: 배포 실패 시 pod 로그 / k8s events 자동 캡처
backend-spring rollout 이 180초 timeout 으로 실패할 때, Gitea Actions
로그에는 timeout 메시지만 나오고 정작 Spring Boot 부팅 단계의 진짜
에러는 pod 안 stdout 에 갇혀 있어서 디버깅 불가.

- if: failure() 조건으로 마지막에 Diagnose step 추가
- kubectl get pods, describe, logs (current + previous), events 출력
- frontend 도 참고용 200줄 출력
- 모든 명령 || true 로 감싸서 진단 자체가 실패해도 다음 단계 진행

이 step 은 진짜 원인 파악되고 안정화되면 제거 예정.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-04-29 07:55:17 +09:00

114 lines
4.6 KiB
YAML

name: Build & Deploy to K8s
on:
push:
branches:
- main
- gbpark-node
env:
REGISTRY: localhost:5000
PROJECT: invyone
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set commit SHA
run: echo "SHORT_SHA=$(echo ${{ github.sha }} | cut -c1-7)" >> $GITHUB_ENV
# ---- Backend Spring ----
- name: Build backend-spring
run: |
docker build -t ${{ env.REGISTRY }}/${{ env.PROJECT }}/backend-spring:${{ env.SHORT_SHA }} \
-f docker/deploy/backend-spring.Dockerfile \
backend-spring/
# ---- Frontend ----
- name: Build frontend
run: |
docker build -t ${{ env.REGISTRY }}/${{ env.PROJECT }}/frontend:${{ env.SHORT_SHA }} \
-f docker/deploy/frontend.Dockerfile \
frontend/
# ---- Push to Registry ----
- name: Push images
run: |
docker push ${{ env.REGISTRY }}/${{ env.PROJECT }}/backend-spring:${{ env.SHORT_SHA }}
docker push ${{ env.REGISTRY }}/${{ env.PROJECT }}/frontend:${{ env.SHORT_SHA }}
# latest 태그
docker tag ${{ env.REGISTRY }}/${{ env.PROJECT }}/backend-spring:${{ env.SHORT_SHA }} ${{ env.REGISTRY }}/${{ env.PROJECT }}/backend-spring:latest
docker tag ${{ env.REGISTRY }}/${{ env.PROJECT }}/frontend:${{ env.SHORT_SHA }} ${{ env.REGISTRY }}/${{ env.PROJECT }}/frontend:latest
docker push ${{ env.REGISTRY }}/${{ env.PROJECT }}/backend-spring:latest
docker push ${{ env.REGISTRY }}/${{ env.PROJECT }}/frontend:latest
# ---- Deploy to K8s ----
- name: Deploy to Kubernetes
run: |
# kubectl은 act_runner가 실행되는 호스트에서 접근 가능
export KUBECONFIG=/home/chpark/.kube/config
kubectl apply -f k8s/namespace.yaml
kubectl apply -f k8s/configmap.yaml
kubectl apply -f k8s/pvc.yaml
kubectl apply -f k8s/backend-spring.yaml
kubectl apply -f k8s/frontend.yaml
kubectl apply -f k8s/networkpolicy.yaml
# Rolling update with new image tag
kubectl set image deployment/backend-spring \
backend-spring=${{ env.REGISTRY }}/${{ env.PROJECT }}/backend-spring:${{ env.SHORT_SHA }} \
-n invyone
kubectl set image deployment/frontend \
frontend=${{ env.REGISTRY }}/${{ env.PROJECT }}/frontend:${{ env.SHORT_SHA }} \
-n invyone
# Rollout 상태 확인
kubectl rollout status deployment/backend-spring -n invyone --timeout=180s
kubectl rollout status deployment/frontend -n invyone --timeout=120s
# ---- 실패 시 진단 (pod stdout / events 캡처) ----
- name: Diagnose on failure
if: failure()
run: |
export KUBECONFIG=/home/chpark/.kube/config
echo "============================================"
echo "=== Pods (-n invyone) ==="
echo "============================================"
kubectl get pods -n invyone -o wide || true
echo
echo "============================================"
echo "=== backend-spring describe ==="
echo "============================================"
kubectl describe deployment backend-spring -n invyone || true
kubectl describe pods -n invyone -l app=backend-spring | tail -120 || true
echo
echo "============================================"
echo "=== backend-spring CURRENT logs (tail 400) ==="
echo "============================================"
kubectl logs -n invyone deployment/backend-spring --tail=400 --all-containers=true || true
echo
echo "============================================"
echo "=== backend-spring PREVIOUS logs (crashed pod, tail 400) ==="
echo "============================================"
kubectl logs -n invyone deployment/backend-spring --tail=400 --previous --all-containers=true || true
echo
echo "============================================"
echo "=== frontend logs (참고, tail 200) ==="
echo "============================================"
kubectl logs -n invyone deployment/frontend --tail=200 --all-containers=true || true
echo
echo "============================================"
echo "=== Recent Warning events ==="
echo "============================================"
kubectl get events -n invyone --sort-by='.lastTimestamp' --field-selector type=Warning 2>/dev/null | tail -30 || true