Fix Jenkinsfile: force recreate + health check

This commit is contained in:
soufiane 2025-10-30 23:25:47 +01:00
parent 2d89adb867
commit cd9f7613ad

46
Jenkinsfile vendored
View File

@ -4,6 +4,8 @@ pipeline {
environment {
REGISTRY = "registry.wk-archi-o24a-15m-g3.fr"
IMAGE_NAME = "the-tip-top-backend"
APP_PATH = "/srv/devops/the-tip-top"
DEPLOY_HOST = "localhost"
}
stages {
@ -18,10 +20,10 @@ pipeline {
stage('Build Docker image') {
steps {
echo "🐳 Construction de limage Docker backend..."
sh """
docker build -t ${REGISTRY}/${IMAGE_NAME}:${BUILD_NUMBER} .
docker tag ${REGISTRY}/${IMAGE_NAME}:${BUILD_NUMBER} ${REGISTRY}/${IMAGE_NAME}:latest
"""
sh '''
docker build -t $REGISTRY/$IMAGE_NAME:${BUILD_NUMBER} .
docker tag $REGISTRY/$IMAGE_NAME:${BUILD_NUMBER} $REGISTRY/$IMAGE_NAME:latest
'''
}
}
@ -29,11 +31,11 @@ pipeline {
steps {
echo "📤 Envoi de limage vers le registre privé..."
withCredentials([usernamePassword(credentialsId: 'registry-credentials', usernameVariable: 'REG_USER', passwordVariable: 'REG_PASS')]) {
sh """
echo $REG_PASS | docker login ${REGISTRY} -u $REG_USER --password-stdin
docker push ${REGISTRY}/${IMAGE_NAME}:${BUILD_NUMBER}
docker push ${REGISTRY}/${IMAGE_NAME}:latest
"""
sh '''
echo "$REG_PASS" | docker login $REGISTRY -u $REG_USER --password-stdin
docker push $REGISTRY/$IMAGE_NAME:${BUILD_NUMBER}
docker push $REGISTRY/$IMAGE_NAME:latest
'''
}
}
}
@ -41,20 +43,32 @@ pipeline {
stage('Deploy') {
steps {
echo "🚀 Déploiement du backend..."
sh """
sh '''
if [ ! -f $APP_PATH/docker-compose.yml ]; then
echo "❌ Fichier docker-compose.yml introuvable !" >&2
exit 1
fi
cd $APP_PATH
docker compose pull backend
docker compose up -d --force-recreate backend
"""
'''
}
}
stage('Health Check') {
steps {
echo "🩺 Vérification du déploiement..."
echo "🩺 Vérification du backend après déploiement..."
script {
def code = sh(script: "curl -s -o /dev/null -w '%{http_code}' https://api.dsp5-archi-o24a-15m-g3.fr || echo 000", returnStdout: true).trim()
if (code != "200") {
error "Le backend ne répond pas correctement (code HTTP ${code})"
def statusCode = sh(
script: "curl -k -s -o /dev/null -w '%{http_code}' https://api.dsp5-archi-o24a-15m-g3.fr || echo 000",
returnStdout: true
).trim()
if (statusCode != '200') {
error("❌ Health check échoué - code HTTP ${statusCode}")
} else {
echo "✅ Health check réussi - backend opérationnel !"
}
}
}
@ -63,7 +77,7 @@ pipeline {
post {
success {
echo "✅ Déploiement du backend réussi."
echo "✅ Déploiement backend terminé avec succès !"
}
failure {
echo "❌ Échec du pipeline backend."