Jenkins Pipeline 持续集成
Jenkins Pipeline 持续集成
Pipeline Script 执行流程
在使用Pipeline之前请确保Jenkins是2.x版本以上,并且安装了Pipeline插件。
Jenkins提供了pipeline
对象,作为配置的入口。它接受一个闭包,在闭包内定义配置:
pipeline {
// do some thing
}
闭包内的方法层级结构(由DSL定义):
- stages
- stage
- steps
- step
- steps
- stage
一个例子:
pipeline {
agent any
stages {
stage('1. 初始化') {
steps {
script {
println("Hello")
}
}
}
}
}
我们创建了一个Jenkins Pipeline Build,在脚本里面写上:
println(pipeline)
构建之后日志打印:
org.jenkinsci.plugins.pipeline.modeldefinition.ModelInterpreter@403c4fdc
实际上pipeline
是ModelInterpreter
一个实例,相当于可以给一个对象传递闭包!通过搜索找到该类所在的项目 pipeline-model-definition-plugin ,克隆下来,找到类ModelInterpreter
简略如下:
class ModelInterpreter implements Serializable {
private CpsScript script
ModelInterpreter(CpsScript script) {
this.script = script
}
def call(CpsClosure closure) {
Root root = (Root) closure.call()
}
推测给对象传递的闭包会调用call
方法,为验证此猜想编写一下代码:
class Person{
def call(Closure c){
c.call()
}
static void main(args){
def p = new Person()
p{
print("Hello")
}
}
}
执行结果:
Hello
由此确认对象是可以接受闭包,并处理的。在call
方法的第一行写着:
Root root = (Root) closure.call()
也就是说我们传给pipeline
实例的闭包也是有要求的,必须是CpsClosure
这种格式的闭包,并且它返回一个Root
对象:
class Root implements Serializable {
Agent agent
Stages stages
}
也就是说我们定义的pipeline闭包配置,最终被Jenkins执行后会得到一个配置对象。
when 条件判断
多分支
Jenkins 可以同时监控多个分支。在集成的过程中,有的分支提交代码可能需要测试,通过之后才能合并;有的分支提交代码可能是可以部署了,我们可以根据不同的分支决定持续集成的操作,通过when
方法可以设置stage
执行的条件:
pipeline{
stages{
stage("init"){
when {
branch 'dev'// 当代码的分支为dev 执行当前stage
}
}
}
}
创建build时需要配合多分支Pipeline使用,这个特性可以通过Pipeline可视化体现出来。
构建参数
创建Build时候可以设置构建参数,通过参数化构建过程
增加一个选项参数,设置名称为TargetImage
,然后就可以设置when
条件了:
when { environment name: 'TargetImage', value: 'Test' }
上面的条件意思为:当对参数TargetImage选择的选项为Test
时才执行当前stage。
支持多个git仓库
我们可以在一个Build中依赖多个git仓库,并且将其代码克隆到不同的文件夹内。
正常情况下客隆一个项目的写法:
checkout([$class: 'GitSCM', branches: [[name: '*/dev']], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: 'xxx', url: 'https://xxx.xxx.git']]])
假如可以指定客隆到本地的目录,那么写多个checkout
指令就可以在一个Build中支持多个源码仓库了;可以在checkout中指定一个extension来设置克隆源码到本地目录:
extensions: [[$class: 'RelativeTargetDirectory', relativeTargetDir: 'model-dissector']]
完整的指令如下:
checkout([$class: 'GitSCM', branches: [[name: '*/dev']], doGenerateSubmoduleConfigurations: false, extensions: [[$class: 'RelativeTargetDirectory', relativeTargetDir: 'model-dissector']], submoduleCfg: [], userRemoteConfigs: [[credentialsId: 'xxx', url: 'https://xxx.xxx.git']]])
我们也可以使用Jenkins自带的代码模板生成,在流水线语法
中选择名称为checkout: Checkout from version control
,然后添加一个Additional Behaviours
选择 Checkout to a sub-directory
就可以了。
并行执行
如果测试阶段有多个单元测试,为了提高速度可以将这些单元测试并行执行。
通过Jenkins可以在Stage中创建并行执行的子Stage,并且为这些Stage分配不同的运行节点。
pipeline{
stages{
stage("init"){
parallel{ // 创建并行的子stages
stage("init 1"){
// do some thing
}
stage("init 2"){
// do some thing
}
}
}
}
}
在上述配置的stagesinit 1
和init 2
中可以分别执行不同的单元测试,并同时运行达到节省时间的目的,这个优势在单元测试较多时候表现比较明显。
Jenkins Pipeline 持续集成的更多相关文章
- 【iOS】Jenkins Gitlab持续集成打包平台搭建
Jenkins Gitlab持续集成打包平台搭建 SkySeraph July. 18th 2016 Email:skyseraph00@163.com 更多精彩请直接访问SkySeraph个人站点: ...
- 使用jenkins构建持续集成平台
jenkins + Maven + svn/git + tomcat 的持续集成平台 项目管理流程: 需求分析----原型设计----开发代码----提交测试-----内部测试-----确认上线( ...
- 用MSBuild和Jenkins搭建持续集成环境(2)
http://www.infoq.com/cn/articles/MSBuild-2 作者 Mustafa Saeed Haji Ali ,译者 李剑 发布于 2012年10月23日 | 注意: ...
- jenkins jmeter持续集成批处理jmx脚本
这篇文章介绍jenkis jmeter的持续集成,利用jenkins定时任务去批处理执行jmeter的jmx脚本文件,并且生成测试报告 1:jmeter的安装这里我就不在赘述了,如有问题可参考我的jm ...
- RF+Jenkins构建持续集成
引入RF是为了能够快速的开展自动化验收测试,Jenkins而一种持续集成工具,用于监控持续重复的工作,持续的软件版本发布/测试项目,而通过RF+Jenkins可以有利的对RF构建的接口项目进行持续集成 ...
- Jenkins+Git 持续集成
持续集成是必要的! 希望达到的效果是:开发同事签入代码后,对应的站点可以自动实现更新.目前还只在在内部服务器上实现开发环境中的站点更新,不涉及到线上的发布. 目前使用Jenkins实现这样的持续集成. ...
- 使用Jenkins进行持续集成ionic3项目
Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能. 网上大多数是关于.net web网站以及 ...
- 使用jenkins实现持续集成
一.jenkins 介绍 它是一个自动化的周期性的集成测试过程,从检出代码.编译构建.运行测试.结果记录.测试统计等都是自动完成的,无需人工干预: 它需要有专门的集成服务器来执行集成构建: 它需要有代 ...
- jenkins+github持续集成中的坑
1.前言 刚开始开发自己的独立博客的时候,每次发布都要手动打包,上传服务器,杀tomcat进程,重启,来回这么重复性工作,很快就有点不耐烦了.如果能自动化的东西,就绝不要手动了,所以自己搭建了个持续集 ...
随机推荐
- 为什么vue中的data用return返回呢?
不使用return包裹的数据会在项目的全局可见,会造成变量污染:使用return包裹后数据中变量只在当前组件中生效,不会影响其他组件. 当一个组件被定义, data 必须声明为返回一个初始数据对象的函 ...
- Spark入门(五)--Spark的reduce和reduceByKey
reduce和reduceByKey的区别 reduce和reduceByKey是spark中使用地非常频繁的,在字数统计中,可以看到reduceByKey的经典使用.那么reduce和reduceB ...
- WEB应用之http协议和httpd闲聊
什么是web?在日常生活中我们常常听到web这个词,它到底是什么呢?今天我们来聊一聊web应用http协议:相信生活在如今互联网时代的我们,http这个协议应该对我们不是很陌生吧!比如双十一双十二我们 ...
- 题解 UVA12186 【工人的请愿书 Another Crisis】
俺太难了 记录一下我调了一个小时的错误 多测不清空 多测清空只清空了\(vector\) 多测全清空了,但是忘了清空\(vector[0]\) \(priority\)_ \(queue\)把\(gr ...
- linux环境下安装可操作图库语言Gremlin的图框架HugeGraph
原创/朱季谦 图数据库是一项比较前沿而逐渐热门的技术,是NoSql数据库的一种,它应用图形理论存储实体之间的关系信息,最主要的组成有两种,结点集和连接结点的边.常见的图数据库有Neo4j,Januas ...
- 《面试经典系列》- 从底层理解==和equals的区别
前言 在我们Java面试中,基础知识基本上比定会考核的点,而“==和equals的区别”则是面试官最喜欢.最经常问的问题. 但我们看了不少的文章.解释,总是一头雾水.一知半解的,往往很容忘记.今天,我 ...
- 如何将自己的测试脚本分离成PO模式的测试框架
1 PO模式 1.1 PO模式介绍 Page Object Model 测试页面和测试脚本分离,即页面封装成类,供测试脚本调用. (将项目分为page.py和test.py) 测试用例:就是excel ...
- red hat重置密码
步骤1:打开red hat 步骤2:看到如图画面时按e 进入到这个界面 步骤4:按e,看到如下画面后,选第二项,然后按e 步骤5:在“quiet"后面输入 空格single 后按b ...
- session生命周期,与cookie的区别
sessinon在用户访问第一次访问服务器时创建. Session什么时候失效? 1. 服务器会把长时间没有活动的Session从服务器内存中清除,此时Session便失效.Tomcat中Sessio ...
- Spark在Windows环境下的配置
1.下载 下载地址:http://spark.apache.org/downloads.html. 选择下面版本下载. 2.操作流程:https://blog.csdn.net/nxw_tsp/art ...