jenkins~管道Pipeline的使用,再见jenkinsUI

Pipeline在Jenkins里的作用

最近一直在使用jenkins进行自动化部署的工作,开始觉得很爽,省去了很多重复的工作,它帮助我自动拉服务器的代码,自动还原包包,自动编译项目,自动发布项目,自动打包镜像,自动上传仓库,自动启动docker服务,这一系列动作都是自动化的,听起来确实很绚,但是,如果项目多了,要进行管理和调整也挺麻烦的,而且修改记录是没有的,不可追踪,而就在这时候,pipeline出现了,它就是jenkins部署的代码方式,它使用groovy脚本编写,有了它,就不用使用jenkins向导了,有了它,你的jenkins变更就可以追踪了(因为它的文件可以放在git,svn上)

 

优点

事实上groovy脚本类似于一个json文件,你可以在里面定义jenkins的节点(分发节点,负载均衡,一台服务器肯定扛不住),编写CI、CD的每个步骤,编译项目,测试项目,打包项目,启动项目,发邮件通知,总之,你用jenkinsUI向导可以实现的,用pipeline都可以实现!

groovy的脚本编写种类有有声明风格和脚本风格两种,根据个人喜好去选择!

从代码中分析语法

@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有一个了解了,事实上,它和gitlab的pipeline非常类似,都是一个流程,从上到下的运行!

在互联网高度发展的今天,大叔觉得,掌握一个CI、CD工具非常必要!

感谢各位的阅读!

posted @ 2017-11-23 22:53  张占岭  阅读(6049)  评论(0编辑  收藏  举报