|
@@ -8,12 +8,13 @@ pipeline {
|
|
SWARM_GIT_URL='ssh://git@git.sdsys.ru:8022/iru/stack-deploy.git'
|
|
SWARM_GIT_URL='ssh://git@git.sdsys.ru:8022/iru/stack-deploy.git'
|
|
SWARM_GIT_NAME='stack-deploy'
|
|
SWARM_GIT_NAME='stack-deploy'
|
|
JENKINS_MAIL='jenkins@sdsys.ru'
|
|
JENKINS_MAIL='jenkins@sdsys.ru'
|
|
|
|
+ NEWTAG=''
|
|
}
|
|
}
|
|
parameters {
|
|
parameters {
|
|
string(
|
|
string(
|
|
- name: "repo",
|
|
|
|
- defaultValue: "prod",
|
|
|
|
- description: "Repository to build and/or deploy from."
|
|
|
|
|
|
+ name: "GitBranch",
|
|
|
|
+ defaultValue: "newPromoSpring",
|
|
|
|
+ description: "Which branch to use"
|
|
)
|
|
)
|
|
string(
|
|
string(
|
|
name: "service_update",
|
|
name: "service_update",
|
|
@@ -36,13 +37,19 @@ pipeline {
|
|
"""
|
|
"""
|
|
}
|
|
}
|
|
echo "Building ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER}."
|
|
echo "Building ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER}."
|
|
- sh "docker build --build-arg repo=${repo} --no-cache -t ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER} ."
|
|
|
|
|
|
+ sh "docker build --build-arg branch=${GitBranch} --no-cache -t ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${BUILD_NUMBER} ."
|
|
|
|
+ script {
|
|
|
|
+ NEWTAG = sh script: "docker run --rm ${DOCKER_REGISTRY}/${DOCKER_IMAGE}:${BUILD_NUMBER} cat /tmp/version 2> /dev/null", returnStdout: true
|
|
|
|
+ NEWTAG = NEWTAG + "_" + BUILD_NUMBER
|
|
|
|
+ echo "NEWTAG is $NEWTAG"
|
|
|
|
+ }
|
|
|
|
+ sh "docker tag ${DOCKER_REGISTRY}/${DOCKER_IMAGE}:${BUILD_NUMBER} ${DOCKER_REGISTRY}/${DOCKER_IMAGE}:${NEWTAG}"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
stage("Publish") {
|
|
stage("Publish") {
|
|
steps {
|
|
steps {
|
|
- echo "Publishing ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER}"
|
|
|
|
- sh "docker push ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER}"
|
|
|
|
|
|
+ echo "Publishing ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${NEWTAG}"
|
|
|
|
+ sh "docker push ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${NEWTAG}"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
stage("Update") {
|
|
stage("Update") {
|
|
@@ -52,7 +59,7 @@ pipeline {
|
|
for (String item : service_update.split()) {
|
|
for (String item : service_update.split()) {
|
|
try{
|
|
try{
|
|
echo "Updating $item"
|
|
echo "Updating $item"
|
|
- sh "docker service update $item --image ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${repo}-${BUILD_NUMBER}"
|
|
|
|
|
|
+ sh "docker service update $item --image ${DOCKER_REGISTRY}/iru/${DOCKER_IMAGE}:${NEWTAG}"
|
|
}
|
|
}
|
|
catch(err){
|
|
catch(err){
|
|
echo "Recovering service $item"
|
|
echo "Recovering service $item"
|
|
@@ -73,7 +80,7 @@ pipeline {
|
|
sh '''GIT_SSH_COMMAND='ssh -i ${GIT_SSH_KEY} -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no' \
|
|
sh '''GIT_SSH_COMMAND='ssh -i ${GIT_SSH_KEY} -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no' \
|
|
git clone ${SWARM_GIT_URL}
|
|
git clone ${SWARM_GIT_URL}
|
|
cd ${SWARM_GIT_NAME}
|
|
cd ${SWARM_GIT_NAME}
|
|
- echo -n ${repo}-${BUILD_NUMBER} > tags/${DOCKER_IMAGE}.version
|
|
|
|
|
|
+ echo -n ${NEWTAG} > tags/${DOCKER_IMAGE}.version
|
|
git add -A
|
|
git add -A
|
|
git config --global user.email "${JENKINS_MAIL}"
|
|
git config --global user.email "${JENKINS_MAIL}"
|
|
git config --global user.name "Jenkins"
|
|
git config --global user.name "Jenkins"
|