✅ Fix Jenkinsfile: force recreate + health check
This commit is contained in:
parent
cd9f7613ad
commit
41c4f63ead
76
Jenkinsfile
vendored
76
Jenkinsfile
vendored
|
|
@ -2,27 +2,42 @@ pipeline {
|
||||||
agent any
|
agent any
|
||||||
|
|
||||||
environment {
|
environment {
|
||||||
REGISTRY = "registry.wk-archi-o24a-15m-g3.fr"
|
REGISTRY_URL = "registry.wk-archi-o24a-15m-g3.fr"
|
||||||
IMAGE_NAME = "the-tip-top-backend"
|
IMAGE_NAME = "the-tip-top-frontend"
|
||||||
APP_PATH = "/srv/devops/the-tip-top"
|
CONTAINER_NAME = "the-tip-top-frontend"
|
||||||
DEPLOY_HOST = "localhost"
|
DEPLOY_PATH = "/srv/devops/the-tip-top"
|
||||||
|
DOMAIN = "dsp5-archi-o24a-15m-g3.fr"
|
||||||
|
API_URL = "https://api.${DOMAIN}"
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
|
|
||||||
stage('Checkout') {
|
stage('Checkout') {
|
||||||
steps {
|
steps {
|
||||||
echo "📦 Récupération du code source..."
|
echo "📦 Récupération du code source depuis Gitea..."
|
||||||
checkout scm
|
checkout scm
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
stage('Install dependencies') {
|
||||||
|
steps {
|
||||||
|
echo "📦 Installation des dépendances NPM..."
|
||||||
|
sh 'npm ci'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('Build Next.js') {
|
||||||
|
steps {
|
||||||
|
echo "⚙️ Compilation de l’application Next.js (production)..."
|
||||||
|
sh 'npm run build'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
stage('Build Docker image') {
|
stage('Build Docker image') {
|
||||||
steps {
|
steps {
|
||||||
echo "🐳 Construction de l’image Docker backend..."
|
echo "🐳 Construction de l’image Docker frontend..."
|
||||||
sh '''
|
sh '''
|
||||||
docker build -t $REGISTRY/$IMAGE_NAME:${BUILD_NUMBER} .
|
docker build -t ${REGISTRY_URL}/${IMAGE_NAME}:${BUILD_NUMBER} .
|
||||||
docker tag $REGISTRY/$IMAGE_NAME:${BUILD_NUMBER} $REGISTRY/$IMAGE_NAME:latest
|
docker tag ${REGISTRY_URL}/${IMAGE_NAME}:${BUILD_NUMBER} ${REGISTRY_URL}/${IMAGE_NAME}:latest
|
||||||
'''
|
'''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -32,9 +47,9 @@ pipeline {
|
||||||
echo "📤 Envoi de l’image vers le registre privé..."
|
echo "📤 Envoi de l’image vers le registre privé..."
|
||||||
withCredentials([usernamePassword(credentialsId: 'registry-credentials', usernameVariable: 'REG_USER', passwordVariable: 'REG_PASS')]) {
|
withCredentials([usernamePassword(credentialsId: 'registry-credentials', usernameVariable: 'REG_USER', passwordVariable: 'REG_PASS')]) {
|
||||||
sh '''
|
sh '''
|
||||||
echo "$REG_PASS" | docker login $REGISTRY -u $REG_USER --password-stdin
|
echo "$REG_PASS" | docker login ${REGISTRY_URL} -u "$REG_USER" --password-stdin
|
||||||
docker push $REGISTRY/$IMAGE_NAME:${BUILD_NUMBER}
|
docker push ${REGISTRY_URL}/${IMAGE_NAME}:${BUILD_NUMBER}
|
||||||
docker push $REGISTRY/$IMAGE_NAME:latest
|
docker push ${REGISTRY_URL}/${IMAGE_NAME}:latest
|
||||||
'''
|
'''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -42,33 +57,44 @@ pipeline {
|
||||||
|
|
||||||
stage('Deploy') {
|
stage('Deploy') {
|
||||||
steps {
|
steps {
|
||||||
echo "🚀 Déploiement du backend..."
|
echo "🚀 Déploiement du frontend..."
|
||||||
sh '''
|
sh '''
|
||||||
if [ ! -f $APP_PATH/docker-compose.yml ]; then
|
if [ ! -f ${DEPLOY_PATH}/docker-compose.yml ]; then
|
||||||
echo "❌ Fichier docker-compose.yml introuvable !" >&2
|
echo "❌ Fichier docker-compose.yml introuvable dans ${DEPLOY_PATH}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cd $APP_PATH
|
cd ${DEPLOY_PATH}
|
||||||
docker compose pull backend
|
docker compose pull frontend
|
||||||
docker compose up -d --force-recreate backend
|
docker compose up -d --force-recreate frontend
|
||||||
'''
|
'''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Health Check') {
|
stage('Health Check') {
|
||||||
steps {
|
steps {
|
||||||
echo "🩺 Vérification du backend après déploiement..."
|
echo "🩺 Vérification du frontend après déploiement..."
|
||||||
script {
|
script {
|
||||||
def statusCode = sh(
|
def maxRetries = 10
|
||||||
script: "curl -k -s -o /dev/null -w '%{http_code}' https://api.dsp5-archi-o24a-15m-g3.fr || echo 000",
|
def statusCode = "000"
|
||||||
|
|
||||||
|
for (int i = 1; i <= maxRetries; i++) {
|
||||||
|
statusCode = sh(
|
||||||
|
script: "curl -k -s -o /dev/null -w '%{http_code}' https://${DOMAIN}/ || echo 000",
|
||||||
returnStdout: true
|
returnStdout: true
|
||||||
).trim()
|
).trim()
|
||||||
|
|
||||||
|
if (statusCode == '200') {
|
||||||
|
echo "✅ Frontend opérationnel (HTTP ${statusCode}) après ${i} essai(s)"
|
||||||
|
break
|
||||||
|
} else {
|
||||||
|
echo "⏳ Tentative ${i}/${maxRetries} → HTTP ${statusCode}"
|
||||||
|
sleep 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (statusCode != '200') {
|
if (statusCode != '200') {
|
||||||
error("❌ Health check échoué - code HTTP ${statusCode}")
|
error("❌ Health check échoué - code HTTP ${statusCode}")
|
||||||
} else {
|
|
||||||
echo "✅ Health check réussi - backend opérationnel !"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -77,10 +103,10 @@ pipeline {
|
||||||
|
|
||||||
post {
|
post {
|
||||||
success {
|
success {
|
||||||
echo "✅ Déploiement backend terminé avec succès !"
|
echo "✅ Pipeline frontend terminé avec succès !"
|
||||||
}
|
}
|
||||||
failure {
|
failure {
|
||||||
echo "❌ Échec du pipeline backend."
|
echo "❌ Échec du pipeline frontend."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user