Update Jenkinsfile

This commit is contained in:
John Hanzu Kim 2025-06-16 18:08:52 +09:00 committed by GitHub
parent 2d17e43ad2
commit 1c461f65f4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -40,7 +40,6 @@ podTemplate(
echo "팀 ID: ${props.teamid}" echo "팀 ID: ${props.teamid}"
} }
// 🔧 핵심 추가: AKS 설정 단계
stage("Setup AKS") { stage("Setup AKS") {
container('azure-cli') { container('azure-cli') {
withCredentials([azureServicePrincipal('azure-credentials')]) { withCredentials([azureServicePrincipal('azure-credentials')]) {
@ -57,8 +56,13 @@ podTemplate(
echo "=== 네임스페이스 생성 ===" echo "=== 네임스페이스 생성 ==="
kubectl create namespace ${namespace} --dry-run=client -o yaml | kubectl apply -f - kubectl create namespace ${namespace} --dry-run=client -o yaml | kubectl apply -f -
echo "=== 현재 컨텍스트 확인 ===" echo "=== Image Pull Secret 생성 ==="
kubectl config current-context kubectl create secret docker-registry acr-secret \\
--docker-server=${props.registry} \\
--docker-username=acrdigitalgarage02 \\
--docker-password=\$(az acr credential show --name acrdigitalgarage02 --query passwords[0].value -o tsv) \\
--namespace=${namespace} \\
--dry-run=client -o yaml | kubectl apply -f -
""" """
} }
} }
@ -163,22 +167,43 @@ podTemplate(
container('azure-cli') { container('azure-cli') {
sh """ sh """
echo "=== kubectl 연결 상태 재확인 ==="
kubectl cluster-info
echo "=== Manifest 적용 ===" echo "=== Manifest 적용 ==="
kubectl apply -f smarketing-java/deployment/${manifest} kubectl apply -f smarketing-java/deployment/${manifest}
echo "=== Deployment 대기 ===" echo "=== 배포 상태 즉시 확인 ==="
kubectl -n ${namespace} wait --for=condition=available deployment/member --timeout=300s kubectl -n ${namespace} get deployments
kubectl -n ${namespace} wait --for=condition=available deployment/store --timeout=300s kubectl -n ${namespace} get pods
kubectl -n ${namespace} wait --for=condition=available deployment/marketing-content --timeout=300s kubectl -n ${namespace} get events --sort-by='.lastTimestamp' | tail -20
kubectl -n ${namespace} wait --for=condition=available deployment/ai-recommend --timeout=300s
echo "=== 배포 상태 확인 ===" echo "=== Pod 상세 정보 확인 ==="
for pod in \$(kubectl -n ${namespace} get pods -o name); do
echo "=== \$pod 상세 정보 ==="
kubectl -n ${namespace} describe \$pod
echo "=== \$pod 로그 ==="
kubectl -n ${namespace} logs \$pod --tail=50 || echo "로그 없음"
echo "================"
done
echo "=== Deployment 대기 (30초 timeout으로 단축) ==="
timeout 30 kubectl -n ${namespace} wait --for=condition=available deployment/member --timeout=30s || echo "member deployment 대기 실패"
timeout 30 kubectl -n ${namespace} wait --for=condition=available deployment/store --timeout=30s || echo "store deployment 대기 실패"
timeout 30 kubectl -n ${namespace} wait --for=condition=available deployment/marketing-content --timeout=30s || echo "marketing-content deployment 대기 실패"
timeout 30 kubectl -n ${namespace} wait --for=condition=available deployment/ai-recommend --timeout=30s || echo "ai-recommend deployment 대기 실패"
echo "=== 최종 배포 상태 확인 ==="
kubectl -n ${namespace} get deployments kubectl -n ${namespace} get deployments
kubectl -n ${namespace} get pods kubectl -n ${namespace} get pods
kubectl -n ${namespace} get services kubectl -n ${namespace} get services
echo "=== 실패한 Pod가 있다면 상세 로그 ==="
for pod in \$(kubectl -n ${namespace} get pods --field-selector=status.phase!=Running -o name 2>/dev/null || true); do
if [ ! -z "\$pod" ]; then
echo "=== 실패한 Pod: \$pod ==="
kubectl -n ${namespace} describe \$pod
kubectl -n ${namespace} logs \$pod --previous --tail=50 2>/dev/null || echo "이전 로그 없음"
kubectl -n ${namespace} logs \$pod --tail=50 2>/dev/null || echo "현재 로그 없음"
fi
done
""" """
} }
} }