| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 | 
							- pipeline {
 
-   agent {
 
-     label "swarm"
 
-   }
 
-   options {
 
-         ansiColor('xterm')
 
-   }
 
-   environment {
 
-     DOCKER_REGISTRY='dev-registry.infoclinica.ru:5000'
 
-     DOCKER_IMAGE='admin-lab'
 
-     SWARM_GIT_URL='ssh://git@git.sdsys.ru:8022/iru/stack-deploy.git'
 
-     SWARM_GIT_NAME='stack-deploy'
 
-     JENKINS_MAIL='jenkins@sdsys.ru'
 
-     CLUSTER_DEV='dev-iru-swarm.infoclinica.lan'
 
-     CLUSTER_PROD='iru-swarm.infoclinica.ru'
 
-   }
 
-   parameters {
 
-     string(
 
-       name: "repo",
 
-       defaultValue: "prod",
 
-       description: "Repository to build and/or deploy from."
 
-     )
 
-     string(
 
-       name: "version",
 
-       defaultValue: "16.1",
 
-       description: "Witch version to build and/or deploy."
 
-     )
 
-     string(
 
-       name: "cluster",
 
-       defaultValue: "dev",
 
-       description: "Cluster to deploy (dev or prod)."
 
-     )
 
-     string(
 
-       name: "service_update",
 
-       defaultValue: "lab_admin",
 
-       description: "Services to update."
 
-     )
 
-     string(
 
-       name: "mailto",
 
-       defaultValue: "admin@sdsys.ru",
 
-       description: "Email which has to be notified."
 
-     )
 
-   }
 
-   stages {
 
-     stage("Build") {
 
-       steps {
 
-         echo "\u001B[32m \u2600 Building \u001B[35m ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER}. \u001B[0m"
 
-         sh "docker build --build-arg repo=${repo} --build-arg version=${version} --no-cache -t ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER} ."
 
-       }
 
-     }
 
- /*    stage("Publish") {
 
-       steps {
 
-         echo "\u001B[32m \u2600 Publishing \u001B[35m ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER} \u001B[0m"
 
-         sh "docker push ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER}"
 
-       }
 
-     }
 
-     stage("Update") {
 
-       when { expression { service_update != "" } }
 
-       steps {
 
-         script {
 
-           for (String item : service_update.split()) {
 
-             try{
 
-               echo "\u001B[32m \u2600 Updating \u27A1 $item \u001B[0m"
 
-               if (cluster == 'prod') {
 
-                 withEnv(["service_name=${item}"]) {
 
-                   sh '''export DOCKER_CERT_PATH=/run/secrets/swarm
 
-                         export DOCKER_HOST=tcp://${CLUSTER_PROD}:2376 DOCKER_TLS_VERIFY=1
 
-                         docker service update ${service_name} --image ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER}
 
-                       '''
 
-                 }
 
-               }
 
-               if (cluster == 'dev') {
 
-                 withEnv(["service_name=${item}"]) {
 
-                   sh '''export DOCKER_CERT_PATH=/run/secrets/swarm
 
-                         export DOCKER_HOST=tcp://${CLUSTER_DEV}:2376 DOCKER_TLS_VERIFY=1
 
-                         docker service update ${service_name} --image ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER}
 
-                      '''
 
-                 }
 
-               }
 
-             }
 
-             catch(err){
 
-               echo "Recovering service $item"
 
-               if (cluster == 'prod') {
 
-                 withEnv(["service_name=${item}"]) {
 
-                   sh '''export DOCKER_CERT_PATH=/run/secrets/swarm
 
-                         export DOCKER_HOST=tcp://${CLUSTER_PROD}:2376 DOCKER_TLS_VERIFY=1
 
-                         docker service rollback ${service_name}
 
-                      '''
 
-                 }
 
-               }
 
-               if (cluster == 'dev') {
 
-                 withEnv(["service_name=${item}"]) {
 
-                   sh '''export DOCKER_CERT_PATH=/run/secrets/swarm
 
-                         export DOCKER_HOST=tcp://${CLUSTER_DEV}:2376 DOCKER_TLS_VERIFY=1
 
-                         docker service rollback ${service_name}
 
-                      '''
 
-                 }
 
-               }
 
-               throw err
 
-             }
 
-           }
 
-         }
 
-       }
 
-     }
 
-     stage("Tagging"){
 
-       steps{
 
-         echo "\u001B[32m \u2600 Setting latest tag \u001B[0m"
 
-         sh '''docker tag ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER} ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:latest
 
-               docker push ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:latest'''
 
-         echo "\u001B[32m \u2600 Updating tag info in \u001B[35m ${SWARM_GIT_NAME} repository \u001B[0m"
 
-         withCredentials([sshUserPrivateKey(credentialsId: 'provision', keyFileVariable: 'GIT_SSH_KEY', passphraseVariable: '', usernameVariable: 'GIT_SSH_USERNAME')]) {
 
-           sh '''GIT_SSH_COMMAND='ssh -i ${GIT_SSH_KEY} -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no' \
 
-                   git clone ${SWARM_GIT_URL}
 
-                 cd ${SWARM_GIT_NAME}
 
-                 echo -n ${repo}-${BUILD_NUMBER} > tags/${DOCKER_IMAGE}.version
 
-                 git add -A
 
-                 git config --global user.email "${JENKINS_MAIL}"
 
-                 git config --global user.name "Jenkins"
 
-                 git commit -m 'Version update'
 
-                 GIT_SSH_COMMAND='ssh -i ${GIT_SSH_KEY} -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no' \
 
-                   git push origin master
 
-                 ls'''
 
-         }
 
-       }
 
-     }
 
- */  }
 
-   post {
 
-     always {
 
-       echo "\u001B[32m \u2600 CleaningUp work diretory \u001B[0m"
 
-       deleteDir()
 
-     }
 
-     failure {
 
-       mail charset: 'UTF-8',
 
-            subject: "Jenkins build ERROR",
 
-            mimeType: 'text/html',
 
-            to: "${mailto}",
 
-            body: "<b>ATTENTION!!!</b> <b><br> Jenkins job failed.\n\n <b><br>Project Name:</b> ${env.JOB_NAME} <b><br>\nBuild Number:</b> ${env.BUILD_NUMBER} <b><br>\nURL Build:</b> ${RUN_DISPLAY_URL}"
 
-     }
 
-     success {
 
-       mail charset: 'UTF-8',
 
-            subject: "Jenkins build SUSCCESS",
 
-            mimeType: 'text/html',
 
-            to: "${mailto}",
 
-            body: "<b>Congradulations!!!</b> <b><br> Jenkins job succefully finished.\n\n <b><br>Project Name:</b> ${env.JOB_NAME} <b><br>\nBuild Number:</b> ${env.BUILD_NUMBER} <b><br>\nURL Build:</b> ${RUN_DISPLAY_URL}"
 
-     }
 
-   }
 
- }
 
 
  |