Pipeline在Jenkins里的效应

近期径直在应用jenkins实行自动化安插的行事,起初觉得很爽,省去了好多双重的办事,它补助自身机动拉服务器的代码,自动还原包包,自动编写翻译项目,自动公布项目,自动打包镜像,自动上传仓库,自动运维docker服务,这一连串动作都以自动化的,听起来实在很绚,不过,若是项目多了,要实行政管理理和调整也挺麻烦的,而且修改记录是不曾的,不可追踪,而就在此时,pipeline出现了,它便是jenkins布置的代码格局,它选取groovy脚本编写,有了它,就不用选择jenkins向导了,有了它,你的jenkins变更就能够追踪了(因为它的文书能够放在git,svn上)

图片 1

 

从代码中分析语法

@Library('common-library') _   //引用一个外部类型

pipeline{
    agent any //声明全局分发节点

    environment {//声明全局变量
        imageName = "svt/test"
        serviceName = "svt-test"
    }

    stages{ //定义构建的步骤
        stage('CI'){//步骤1,名称为CI,自定义即可
            agent {label 'build'}//指定一个分发节点 
            steps{//CI步骤里的具体动作
                cleanWs()
                gitScm("${repoUrl}","${branch}","${credentialsId}")//从git上拉一个代码下到build节点
                               }
                //把这个项目在docker提供的aspnetcore镜像里运行
                dir("${deployPath}") {
                    sh "docker run --rm --tty --user root -v ${WORKSPACE}/:/src/ --workdir=/src/deploy/ microsoft/dotnet sh publish.sh"
                    buildImage("${imageName}")
                }
            }
        }

        stage('ServiceRun'){
            agent {label 'svt'}//启动docker服务的节点
            steps{
              startService("${serviceName}","${imageName}")//启动服务
            }
        }
    }

因而地点的代码介绍,大家应该对jenkins
pipeline有1个理解了,事实上,它和gitlab的pipeline分外类似,都以三个流水生产线,从上到下的运作!

在互连网中度发展的前些天,二叔觉得,领会二个CI、CD工具10分须要!

多谢各位的读书!

优点

实则groovy脚本类似于三个json文件,你能够在里面定义jenkins的节点(分发节点,负载均衡,一台服务器一定扛不住),编写CI、CD的每一个步骤,编写翻译项目,测试项目,打包项目,运营项目,发邮件布告,总而言之,你用jenkinsUI向导可以兑现的,用pipeline都可以达成!

groovy的本子编辑撰写连串有有扬言风格宁海平级调动本风格三种,依据个体喜好去选拔!

相关文章

网站地图xml地图