Jenkinsfile & compose restored
This commit is contained in:
parent
7836dce294
commit
047571cad2
|
@ -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;
|
||||
|
|
|
@ -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
|
||||
|
|
Loading…
Reference in New Issue