✅ Fix Jenkinsfile: force recreate + health check
This commit is contained in:
parent
2c7546c67e
commit
de5131b84f
51
Jenkinsfile
vendored
51
Jenkinsfile
vendored
|
|
@ -1,69 +1,58 @@
|
||||||
pipeline {
|
pipeline {
|
||||||
agent {
|
agent any
|
||||||
docker {
|
|
||||||
image 'node:20'
|
|
||||||
args '-v /var/run/docker.sock:/var/run/docker.sock'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
environment {
|
environment {
|
||||||
APP_NAME = "the-tip-top-backend"
|
|
||||||
REGISTRY = "registry.wk-archi-o24a-15m-g3.fr"
|
REGISTRY = "registry.wk-archi-o24a-15m-g3.fr"
|
||||||
IMAGE = "${REGISTRY}/${APP_NAME}:${BUILD_NUMBER}"
|
IMAGE_NAME = "the-tip-top-backend"
|
||||||
DEPLOY_PATH = "/srv/devops/the-tip-top"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
|
|
||||||
stage('Checkout') {
|
stage('Checkout') {
|
||||||
steps {
|
steps {
|
||||||
echo "📦 Récupération du code source depuis Gitea..."
|
echo "📦 Récupération du code source..."
|
||||||
checkout scm
|
checkout scm
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Install dependencies') {
|
|
||||||
steps {
|
|
||||||
echo "📦 Installation des dépendances NPM..."
|
|
||||||
sh 'npm ci'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
stage('Build Docker image') {
|
stage('Build Docker image') {
|
||||||
steps {
|
steps {
|
||||||
echo "🐳 Construction et tag de l’image Docker..."
|
echo "🐳 Construction de l’image Docker backend..."
|
||||||
sh 'docker build -t ${IMAGE} .'
|
sh """
|
||||||
|
docker build -t ${REGISTRY}/${IMAGE_NAME}:${BUILD_NUMBER} backend
|
||||||
|
docker tag ${REGISTRY}/${IMAGE_NAME}:${BUILD_NUMBER} ${REGISTRY}/${IMAGE_NAME}:latest
|
||||||
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Push to Registry') {
|
stage('Push to Registry') {
|
||||||
steps {
|
steps {
|
||||||
echo "📤 Envoi de l’image vers le registry privé..."
|
echo "📤 Envoi de l’image vers le registre privé..."
|
||||||
withCredentials([usernamePassword(credentialsId: 'registry-creds', usernameVariable: 'USER', passwordVariable: 'PASS')]) {
|
withCredentials([usernamePassword(credentialsId: 'registry-credentials', usernameVariable: 'REG_USER', passwordVariable: 'REG_PASS')]) {
|
||||||
sh 'echo $PASS | docker login $REGISTRY -u $USER --password-stdin'
|
sh """
|
||||||
sh 'docker push $IMAGE'
|
echo $REG_PASS | docker login ${REGISTRY} -u $REG_USER --password-stdin
|
||||||
|
docker push ${REGISTRY}/${IMAGE_NAME}:${BUILD_NUMBER}
|
||||||
|
docker push ${REGISTRY}/${IMAGE_NAME}:latest
|
||||||
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Deploy') {
|
stage('Deploy') {
|
||||||
steps {
|
steps {
|
||||||
echo "🚀 Déploiement du backend via Docker Compose..."
|
echo "🚀 Déploiement du backend..."
|
||||||
sh """
|
sh """
|
||||||
cd ${DEPLOY_PATH}
|
|
||||||
docker compose pull backend
|
docker compose pull backend
|
||||||
docker compose up -d --no-deps --build backend
|
docker compose up -d --force-recreate backend
|
||||||
"""
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
post {
|
post {
|
||||||
success {
|
|
||||||
echo "✅ Déploiement du backend réussi !"
|
|
||||||
}
|
|
||||||
failure {
|
failure {
|
||||||
echo "❌ Échec du pipeline backend."
|
echo "❌ Échec du pipeline backend."
|
||||||
}
|
}
|
||||||
|
success {
|
||||||
|
echo "✅ Déploiement backend réussi."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user