Update 'Jenkinsfile'
parent
4ce0ad9765
commit
f978d883f6
@ -1,107 +1,96 @@
|
||||
pipeline {
|
||||
agent any
|
||||
|
||||
|
||||
environment {
|
||||
// Replace with your Docker Hub username/organization
|
||||
DOCKER_HUB_USERNAME = 'aimodocker'
|
||||
// Use credentials for Docker Hub
|
||||
DOCKER_CREDENTIALS = credentials('aimodocker')
|
||||
// Replace with your image name
|
||||
// This creates DOCKER_AUTH_USR and DOCKER_AUTH_PSW
|
||||
DOCKER_AUTH = credentials('aimodocker')
|
||||
IMAGE_NAME = 'lcca-service'
|
||||
// Replace with your docker compose service name
|
||||
SERVICE_NAME = 'lcca-app'
|
||||
// Variable for Git commit hash
|
||||
GIT_COMMIT_HASH = ''
|
||||
SERVICE_NAME = 'ahm-app'
|
||||
|
||||
SECURITY_PREFIX = 'security'
|
||||
|
||||
// Replace with the SSH credentials for development server
|
||||
// SSH_CREDENTIALS = credentials('backend-server-digitaltwin')
|
||||
// SSH_CREDENTIALS_USR = 'aimo'
|
||||
// SSH_SERVER_IP = '192.168.1.82'
|
||||
// Initialize variables to be updated in script blocks
|
||||
GIT_COMMIT_HASH = ""
|
||||
IMAGE_TAG = ""
|
||||
SECONDARY_TAG = ""
|
||||
}
|
||||
|
||||
|
||||
stages {
|
||||
stage('Checkout') {
|
||||
stage('Checkout & Setup') {
|
||||
steps {
|
||||
script {
|
||||
// Checkout and get git commit hash
|
||||
checkout scm
|
||||
def commitHash = sh(script: 'git rev-parse --short HEAD', returnStdout: true).trim()
|
||||
GIT_COMMIT_HASH = commitHash
|
||||
echo "Git commit hash: ${GIT_COMMIT_HASH}"
|
||||
GIT_COMMIT_HASH = sh(script: 'git rev-parse --short HEAD', returnStdout: true).trim()
|
||||
|
||||
// Use env.BRANCH_NAME or logic to handle detached HEAD if necessary
|
||||
def branch = env.BRANCH_NAME ?: 'unknown'
|
||||
echo "Current Branch: ${branch}"
|
||||
|
||||
if (branch == 'main') {
|
||||
IMAGE_TAG = GIT_COMMIT_HASH
|
||||
SECONDARY_TAG = 'latest'
|
||||
} else if (branch == 'lcca_security') {
|
||||
IMAGE_TAG = "${SECURITY_PREFIX}-${GIT_COMMIT_HASH}"
|
||||
SECONDARY_TAG = "${SECURITY_PREFIX}-latest"
|
||||
} else {
|
||||
IMAGE_TAG = "temp-${GIT_COMMIT_HASH}"
|
||||
SECONDARY_TAG = "" // Ensure it's empty for other branches
|
||||
}
|
||||
|
||||
echo "Primary Tag: ${IMAGE_TAG}"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
stage('Docker Login') {
|
||||
steps {
|
||||
sh '''
|
||||
echo ${DOCKER_CREDENTIALS_PSW} | docker login -u ${DOCKER_CREDENTIALS_USR} --password-stdin
|
||||
'''
|
||||
// Fixed variable names based on the 'DOCKER_AUTH' environment key
|
||||
sh "echo ${DOCKER_AUTH_PSW} | docker login -u ${DOCKER_AUTH_USR} --password-stdin"
|
||||
}
|
||||
}
|
||||
|
||||
stage('Build Docker Image') {
|
||||
|
||||
stage('Build & Tag') {
|
||||
steps {
|
||||
script {
|
||||
// Build with commit hash tag
|
||||
sh """
|
||||
docker build -t ${DOCKER_HUB_USERNAME}/${IMAGE_NAME}:latest .
|
||||
docker tag ${DOCKER_HUB_USERNAME}/${IMAGE_NAME}:latest ${DOCKER_HUB_USERNAME}/${IMAGE_NAME}:${GIT_COMMIT_HASH}
|
||||
"""
|
||||
def fullImageName = "${DOCKER_HUB_USERNAME}/${IMAGE_NAME}"
|
||||
sh "docker build -t ${fullImageName}:${IMAGE_TAG} ."
|
||||
|
||||
if (SECONDARY_TAG) {
|
||||
sh "docker tag ${fullImageName}:${IMAGE_TAG} ${fullImageName}:${SECONDARY_TAG}"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
stage('Push to Docker Hub') {
|
||||
steps {
|
||||
sh """
|
||||
# Push both tags
|
||||
docker push ${DOCKER_HUB_USERNAME}/${IMAGE_NAME}:${GIT_COMMIT_HASH}
|
||||
docker push ${DOCKER_HUB_USERNAME}/${IMAGE_NAME}:latest
|
||||
"""
|
||||
script {
|
||||
def fullImageName = "${DOCKER_HUB_USERNAME}/${IMAGE_NAME}"
|
||||
sh "docker push ${fullImageName}:${IMAGE_TAG}"
|
||||
|
||||
if (SECONDARY_TAG) {
|
||||
sh "docker push ${fullImageName}:${SECONDARY_TAG}"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// stage('Deploy') {
|
||||
// steps {
|
||||
// script {
|
||||
// sshagent(credentials: ['backend-server-digitaltwin']) {
|
||||
// sh """
|
||||
// ssh -o StrictHostKeyChecking=no -p 12558 aimo@0.tcp.ap.ngrok.io '
|
||||
// cd ~/digital-twin/Docker
|
||||
// sudo docker compose pull ${SERVICE_NAME}
|
||||
// sudo docker compose up -d ${SERVICE_NAME}
|
||||
// '
|
||||
// """
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
}
|
||||
|
||||
|
||||
post {
|
||||
always {
|
||||
// Clean up
|
||||
sh 'docker logout'
|
||||
|
||||
// Clean up local images
|
||||
script {
|
||||
try {
|
||||
sh """
|
||||
# Push both tags
|
||||
docker rmi ${DOCKER_HUB_USERNAME}/${IMAGE_NAME}:${GIT_COMMIT_HASH}
|
||||
docker rmi ${DOCKER_HUB_USERNAME}/${IMAGE_NAME}:latest
|
||||
"""
|
||||
} catch (err) {
|
||||
echo "Failed to clean up images: ${err}"
|
||||
sh 'docker logout'
|
||||
def fullImageName = "${DOCKER_HUB_USERNAME}/${IMAGE_NAME}"
|
||||
// Clean up images to save agent disk space
|
||||
sh "docker rmi ${fullImageName}:${IMAGE_TAG} || true"
|
||||
if (SECONDARY_TAG) {
|
||||
sh "docker rmi ${fullImageName}:${SECONDARY_TAG} || true"
|
||||
}
|
||||
}
|
||||
}
|
||||
success {
|
||||
echo "Successfully built, pushed, and deployed Docker image with tags: latest and ${GIT_COMMIT_HASH}"
|
||||
}
|
||||
failure {
|
||||
echo 'Failed to build/push/deploy Docker image!'
|
||||
echo "Successfully processed ${env.BRANCH_NAME}."
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue