Jenkins 使用agent docker构建pipeline
此处用于记录,使用jenkins pipeline构建时,使用docker启动一个agent来构建编译环境。
// 需要在jenkins的Credentials设置中配置jenkins-harbor-creds、jenkins-k8s-config参数
pipeline {
agent any
environment {
HARBOR_CREDS = credentials('jenkins-harbor-creds')
K8S_CONFIG = credentials('jenkins-k8s-config')
SONAR_HOME = tool('sonar-scanner')
HARBOR_HOST= credentials('harbor-host')
// git tag 需要使用x.x.x的形式
GIT_TAG = sh(returnStdout: true,script: "#!/bin/bash \n if [[ `git describe --tags --always` =~ '-g' ]] ;then echo 'latest' ; elif [[ `git describe --tags --always` =~ '.' ]] ; then echo `git describe --tags --always` ; else echo 'latest' ;fi").trim()
}
parameters {
string(name: 'DOCKER_IMAGE', defaultValue: 'xx/xxx', description: 'docker镜像名')
string(name: 'APP_NAME', defaultValue: 'xxx', description: 'k8s中标签名')
string(name: 'K8S_DEV_NAMESPACE', defaultValue: 'xxx', description: '开发环境k8s的namespace名称')
string(name: 'K8S_TEST_NAMESPACE', defaultValue: 'xxx', description: '测试环境k8s的namespace名称')
}
stages {
stage('Maven Build') {
agent {
docker {
image 'maven:3-jdk-8-alpine'
args '-v $HOME/.m2:/root/.m2'
}
}
steps {
sh 'mvn -U clean org.jacoco:jacoco-maven-plugin:prepare-agent package -Dfile.encoding=UTF-8'
stash includes: 'target/', name: 'app'
}
}
stage('Sonar') {
steps {
unstash 'app'
withSonarQubeEnv('sonar-server') {
sh 'echo ${SONAR_HOME} ${APP_NAME}'
sh '${SONAR_HOME}/bin/sonar-scanner -Dsonar.projectKey=${APP_NAME} -Dsonar.projectName=${APP_NAME} -Dsonar.language=java -Dsonar.java.binaries=./target/classes -Dsonar.sources=./src -Dsonar.core.codeCoveragePlugin=jacoco -Dsonar.dynamicAnalysis=reuseReports -Dsonar.surefire.reportsPath=target/surefire-reports -Dsonar.jacoco.reportPaths=target/jacoco.exec -Dsonar.jacoco.itReportPath=target/jacoco.exec -Dsonar.java.source=1.8'
}
}
}
stage('Jacoco'){
steps {
jacoco()
}
}
stage('Docker Build') {
when { not { environment name: 'GIT_TAG', value: 'latest' } }
steps {
unstash 'app'
sh "docker login -u ${HARBOR_CREDS_USR} -p ${HARBOR_CREDS_PSW} ${HARBOR_HOST}"
sh "docker build --build-arg JAR_FILE=`ls target/*.jar |cut -d '/' -f2` -t ${HARBOR_HOST}/${params.DOCKER_IMAGE}:${GIT_TAG} ."
sh "docker push ${HARBOR_HOST}/${params.DOCKER_IMAGE}:${GIT_TAG}"
sh "docker rmi ${HARBOR_HOST}/${params.DOCKER_IMAGE}:${GIT_TAG}"
}
}
stage('Deploy test') {
when { not { environment name: 'GIT_TAG', value: 'latest' } }
agent {
docker {
image 'lwolf/helm-kubectl-docker'
}
}
steps {
sh "mkdir -p ~/.kube"
sh "echo ${K8S_CONFIG} | base64 -d > ~/.kube/config"
sh "sed -e 's#{IMAGE_URL}#${HARBOR_HOST}/${params.DOCKER_IMAGE}#g;s#{IMAGE_TAG}#${GIT_TAG}#g;s#{APP_NAME}#${params.APP_NAME}#g;s#{SPRING_PROFILE}#test#g;s#{NAME_SPACE}#${params.K8S_TEST_NAMESPACE}#g' k8s-deployment.tpl > k8s-deployment.yml"
sh "kubectl delete -f k8s-deployment.yml --namespace=${params.K8S_TEST_NAMESPACE} --ignore-not-found"
sh "kubectl apply -f k8s-deployment.yml --namespace=${params.K8S_TEST_NAMESPACE}"
}
}
}
post {
always {
cleanWs()
script {
wrap([$class: 'BuildUser']) {
manager.addShortText("${BUILD_USER}")
manager.addShortText("${APP_NAME}")
manager.addShortText("${TAG}")
manager.addShortText("${K8S_TEST_NAMESPACE}")
}
if (env.ACTION == "Deploy"){
def cr = new Date("${TAG}" as long).format("yyyyMMddHHmmss")
manager.addShortText(cr)
}
}
}
}
}