From 1e89fac663db6f42cf47f76a4406e2fd5f7f1afd Mon Sep 17 00:00:00 2001 From: Thanakarn Klangkasame <77600906+Simulationable@users.noreply.github.com> Date: Tue, 30 Sep 2025 13:19:59 +0700 Subject: [PATCH] Fix Jenkinsfile --- Jenkinsfile | 85 ++++++++++++++--------------------------------------- 1 file changed, 22 insertions(+), 63 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 0149534..073e936 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -5,27 +5,22 @@ pipeline { timeout(time: 25, unit: 'MINUTES') buildDiscarder(logRotator(numToKeepStr: '20', artifactNumToKeepStr: '10')) } - - // ถ้าอยากมี fallback polling ทุก 2 นาที แทนที่จะพึ่งแต่ webhook: // triggers { pollSCM('H/2 * * * *') } environment { REGISTRY = 'registry.aetherframe.tech' - IMAGE = 'simulationable/eop-services-api' // แนะนำพิมพ์เล็กล้วน - APP_PORT = '8080' // Kestrel ใน container - HOST_PORT = '5002' // พอร์ตฝั่ง host (Nginx ยิงเข้า) + IMAGE = 'simulationable/eop-services-api' + APP_PORT = '8080' + HOST_PORT = '5002' } stages { - - stage('Checkout') { - steps { checkout scm } - } + stage('Checkout'){ steps { checkout scm } } stage('Preflight diagnostics') { steps { sh ''' - set -euxo pipefail + set -eux echo "== System ==" whoami || true id || true @@ -50,43 +45,35 @@ pipeline { } } - stage('Unit Tests (optional)') { + stage('Unit Tests (optional)'){ when { expression { fileExists('AMREZ.EOP.sln') } } steps { sh ''' - set -euxo pipefail + set -eux docker run --rm -v "$PWD":/src -w /src mcr.microsoft.com/dotnet/sdk:9.0 \ - bash -lc "dotnet test --configuration Release --nologo --logger trx || true" + bash -lc "set -euo pipefail; dotnet test --configuration Release --nologo --logger trx || true" ''' } } - stage('Docker Build') { + stage('Docker Build'){ steps { script { - // รองรับทั้ง Multibranch (BRANCH_NAME) และ Pipeline เดี่ยว (GIT_BRANCH) def branch = (env.BRANCH_NAME ?: env.GIT_BRANCH ?: sh(script: 'git rev-parse --abbrev-ref HEAD', returnStdout: true).trim()) - .replaceFirst(/^origin\\//,'') - .toLowerCase() + .replaceFirst(/^origin\\//,'').toLowerCase() def commit = sh(script: 'git rev-parse --short=12 HEAD', returnStdout: true).trim() def tag = "${branch}-${env.BUILD_NUMBER}" - - env.IMAGE_TAG = tag - env.IMAGE_COMMIT = commit - env.IMAGE_BRANCH = branch + env.IMAGE_TAG = tag sh """ - set -euxo pipefail + set -eux echo "Building image: ${REGISTRY}/${IMAGE}:${tag}" docker build --pull --progress=plain \\ - --label org.opencontainers.image.source="${env.GIT_URL ?: 'gitea'}" \\ --label org.opencontainers.image.revision="${commit}" \\ -t ${REGISTRY}/${IMAGE}:${tag} \\ -t ${REGISTRY}/${IMAGE}:latest \\ . - echo "== Built images ==" docker images ${REGISTRY}/${IMAGE} --digests || true - echo "== Inspect built image ==" docker inspect ${REGISTRY}/${IMAGE}:${tag} --format='ID={{.Id}} Size={{.Size}}' || true """ } @@ -96,81 +83,53 @@ pipeline { stage('Diagnose registry before push') { steps { sh ''' - set -euxo pipefail + set -eux getent hosts ${REGISTRY} || true curl -sS -I https://${REGISTRY}/v2/ || true - echo "Local images matching ${REGISTRY}/${IMAGE}:" docker images ${REGISTRY}/${IMAGE} --digests || true - """ ''' } } - stage('Docker Push') { + stage('Docker Push'){ steps { - withCredentials([usernamePassword(credentialsId: 'registry-basic', - usernameVariable: 'REG_USER', passwordVariable: 'REG_PASS')]) { + withCredentials([usernamePassword(credentialsId:'registry-basic', usernameVariable:'REG_USER', passwordVariable:'REG_PASS')]){ sh ''' - set -euxo pipefail - echo "Login registry ${REGISTRY} as $REG_USER" + set -eux docker logout ${REGISTRY} || true echo "$REG_PASS" | docker login ${REGISTRY} -u "$REG_USER" --password-stdin - - echo "Pushing tags: ${REGISTRY}/${IMAGE}:${IMAGE_TAG} and :latest" docker push ${REGISTRY}/${IMAGE}:${IMAGE_TAG} docker push ${REGISTRY}/${IMAGE}:latest - - echo "== Verify tags on registry ==" - # ไม่พึ่ง jq เพื่อกัน dependency — แสดง JSON ดิบๆพอ curl -sS -u "$REG_USER:$REG_PASS" https://${REGISTRY}/v2/${IMAGE}/tags/list || true - docker logout ${REGISTRY} || true ''' } } } - stage('Deploy (same host)') { + stage('Deploy (same host)'){ when { branch 'main' } steps { sh """ - set -euxo pipefail - echo "Stopping previous container if exists..." + set -eux docker rm -f eop-services-api || true - - echo "Starting container from ${REGISTRY}/${IMAGE}:latest" docker run -d --name eop-services-api \\ -p 127.0.0.1:${HOST_PORT}:${APP_PORT} \\ -e ASPNETCORE_URLS=http://+:${APP_PORT} \\ --restart=always \\ ${REGISTRY}/${IMAGE}:latest - - echo "== ps/logs ==" sleep 2 docker ps --no-trunc | sed -n '1,5p' || true docker logs --tail=200 eop-services-api || true - - echo "== App health (best effort) ==" - for i in \$(seq 1 30); do - (curl -fsS http://127.0.0.1:${HOST_PORT}/health || \\ - curl -fsS http://127.0.0.1:${HOST_PORT}/) && break || true - sleep 1 - done || true + (curl -fsS http://127.0.0.1:${HOST_PORT}/health || curl -fsS http://127.0.0.1:${HOST_PORT}/) || true """ } } } post { - success { - echo "✅ Deployed at http://127.0.0.1:${HOST_PORT} (จะเข้า https ผ่าน Nginx หลังตั้งค่า vhost)" - } - failure { - echo "❌ Failed — ดู log ของ stages: Preflight, Diagnose registry, Docker Push เพื่อหาสาเหตุ" - } - always { - echo "Cleaning workspace…" - cleanWs() - } + success { echo "✅ Deployed at http://127.0.0.1:${HOST_PORT}" } + failure { echo "❌ Failed — ดูสเตจ Preflight/Push เพื่อตามต่อ" } + always { echo "Cleaning workspace…"; cleanWs() } } }