diff --git a/Jenkinsfile b/Jenkinsfile index 10f78ee78..f1cfe51ff 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -1,80 +1,108 @@ #!/usr/bin/env groovy -def buildError - -try { - switch (env.BRANCH_NAME) { - case 'master': - env.NODE_ENV = 'production' - break; - case 'test': - env.NODE_ENV = 'test' - break; - case 'dev': - env.NODE_ENV = 'development' - break; +pipeline { + agent any + environment { + REGISTRY = 'registry.verdnatura.es' + DOCKER_HOST_1 = 'tcp://vch1.verdnatura.es:2376' + DOCKER_HOST_2 = 'tcp://vch2.verdnatura.es:2376' + TAG = "${env.BRANCH_NAME}" } + stages { + stage('Checkout') { + steps { + script { + env.COMPOSE_PROJECT_NAME = env.JOB_NAME.replace('/', '-'); + env.GIT_COMMITTER_EMAIL = sh( + script: "git --no-pager show -s --format='%ae'", + returnStdout: true + ).trim() - node { - stage ('Checkout') { - checkout scm - env.GIT_COMMITTER_EMAIL = sh( - script: "git --no-pager show -s --format='%ae'", - returnStdout: true - ).trim() - echo "Committer: ${env.GIT_COMMITTER_EMAIL}" - } - stage ('Build') { - nodejs('node-lts') { - sh "env NODE_ENV= npm install --no-audit" - sh "gulp install" - sh "gulp build" - } - } - stage ('Deploy') { - withCredentials([dockerCert(credentialsId: 'docker', variable: 'DOCKER_CERT_PATH')]) { - switch (env.BRANCH_NAME) { - case 'master': - env.PORT = 5000 - break; - case 'test': - env.PORT = 5001 - break; + switch (env.BRANCH_NAME) { + case 'master': + env.PORT = 5002 + break; + case 'test': + env.PORT = 5001 + break; + } + switch (env.BRANCH_NAME) { + case 'master': + env.NODE_ENV = 'production' + break; + case 'test': + env.NODE_ENV = 'test' + break; + case 'dev': + env.NODE_ENV = 'development' + break; + } } - - env.COMPOSE_PROJECT_NAME = env.JOB_NAME.replace('/', '-'); - env.DOCKER_TLS_VERIFY = 1 - env.TAG = env.BRANCH_NAME - - env.DOCKER_HOST = 'tcp://vch1.verdnatura.es:2376'; - sh "docker-compose up --build -d" - - env.DOCKER_HOST = 'tcp://vch2.verdnatura.es:2376'; - sh "docker-compose up --build -d" + echo "Committer: ${env.GIT_COMMITTER_EMAIL}" + } + } + stage('Build') { + environment { + CREDS = credentials('docker-registry') + } + steps { + nodejs('node-lts') { + withEnv(['NODE_ENV=']) { + sh "npm install --no-audit" + sh "gulp install" + } + sh "gulp build" + } + sh 'docker login --username $CREDS_USR --password $CREDS_PSW $REGISTRY' + sh "docker-compose build --parallel" + sh "docker-compose push" + } + } + stage('Deploy') { + environment { + DOCKER_TLS_VERIFY = 1 + } + parallel { + stage('Host 1') { + environment { + DOCKER_HOST = "${env.DOCKER_HOST_1}" + } + steps { + withCredentials([dockerCert(credentialsId: 'docker', variable: 'DOCKER_CERT_PATH')]) { + sh "docker-compose pull" + sh "docker-compose up -d" + } + } + } + stage('Host 2') { + environment { + DOCKER_HOST = "${env.DOCKER_HOST_2}" + } + steps { + withCredentials([dockerCert(credentialsId: 'docker', variable: 'DOCKER_CERT_PATH')]) { + sh "docker-compose pull" + sh "docker-compose up -d" + } + } + } + } + } + stage('Cleanup') { + steps { + sh 'docker logout $REGISTRY' } } } -} catch(e) { - buildError = e -} - -if (env.GIT_COMMITTER_EMAIL) { - def status - def body = "Check status at ${env.BUILD_URL}" - - if (buildError) { - status = 'Failed' - body += "\n\nError: ${buildError.toString()}" - } else { - status = 'Success' + post { + always { + script { + if (!env.GIT_COMMITTER_EMAIL) return + mail( + to: env.GIT_COMMITTER_EMAIL, + subject: "Pipeline: ${env.JOB_NAME} (${env.BUILD_NUMBER}): ${currentBuild.currentResult}", + body: "Check status at ${env.BUILD_URL}" + ) + } + } } - - mail( - to: env.GIT_COMMITTER_EMAIL, - subject: "Pipeline: ${status}: ${env.JOB_NAME} (${env.BUILD_NUMBER})", - body: body - ) } - -if (buildError) - throw buildError; diff --git a/docker-compose.yml b/docker-compose.yml index 9787368aa..317557eb2 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -1,20 +1,20 @@ version: '3.5' services: app: + image: registry.verdnatura.es/salix-app:${TAG} + restart: unless-stopped build: context: . dockerfile: services/nginx/Dockerfile ports: - ${PORT}:80 - image: salix-app:${TAG} - restart: unless-stopped links: - api api: + image: registry.verdnatura.es/salix-api:${TAG} + restart: unless-stopped build: . environment: - NODE_ENV - restart: unless-stopped - image: salix-api:${TAG} volumes: - /containers/salix:/etc/salix