✅ Fix Jenkinsfile: force recreate + health check
This commit is contained in:
parent
2d89adb867
commit
cd9f7613ad
46
Jenkinsfile
vendored
46
Jenkinsfile
vendored
|
|
@ -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 l’image 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 l’image 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."
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user