Jenkins pipeline 并行执行任务流

》一文中介绍了如何在声明式 pipeline 中执行并行的任务。前一段时间,Jenkins 发布了 1.3 版的声明式 pipeline(declarative pipeline),这个版本继续增强了并行执行任务的能力:并行执行的任务可以是个任务流。官方称这一功能为 "sequential stages",本文将解释 "sequential stages",并通过 demo 演示其用法。

》一文中介绍的方式,我们在一个 stage 中设置多个子 stage 并行执行:

stages { stage(</span><span style="color: #800000"&gt;'</span><span style="color: #800000"&gt;Stage1</span><span style="color: #800000"&gt;'</span><span style="color: #000000"&gt;) { agent { label </span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;master</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt; } steps { timestamps { </span><span style="color: #0000ff"&gt;echo</span> <span style="color: #800000"&gt;'</span><span style="color: #800000"&gt;这是第一个被执行的 stage.</span><span style="color: #800000"&gt;'</span> <span style="color: #0000ff"&gt;sleep</span> <span style="color: #800080"&gt;5</span><span style="color: #000000"&gt; } } } stage(</span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;build,deploy and test on Windows and Linux</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt;) { parallel { stage(</span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;windows</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt;) { agent { label </span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;master</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt; } stages { stage(</span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;build</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt;) { steps { timestamps { </span><span style="color: #0000ff"&gt;echo</span> <span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;build on windows.</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt; } } } stage(</span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;deploy</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt;) { steps { timestamps { </span><span style="color: #0000ff"&gt;echo</span> <span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;deploy on windows.</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt; } } } stage(</span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;test</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt;) { steps { timestamps { </span><span style="color: #0000ff"&gt;echo</span> <span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;test on windows.</span><span style="color: #800000"&gt;"</span> <span style="color: #0000ff"&gt;sleep</span> <span style="color: #800080"&gt;5</span><span style="color: #000000"&gt; } } } } } stage(</span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;linux</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt;) { agent { label </span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;worker1</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt; } stages { stage(</span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;build</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt;) { steps { timestamps { </span><span style="color: #0000ff"&gt;echo</span> <span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;build on linux.</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt; } } } stage(</span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;deploy</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt;) { steps { timestamps { </span><span style="color: #0000ff"&gt;echo</span> <span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;deploy on linux.</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt; } } } stage(</span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;test</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt;) { steps { timestamps { </span><span style="color: #0000ff"&gt;echo</span> <span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;test on linux.</span><span style="color: #800000"&gt;"</span> <span style="color: #0000ff"&gt;sleep</span> <span style="color: #800080"&gt;5</span><span style="color: #000000"&gt; } } } } } } } stage(</span><span style="color: #800000"&gt;'</span><span style="color: #800000"&gt;Stage3</span><span style="color: #800000"&gt;'</span><span style="color: #000000"&gt;) { agent { label </span><span style="color: #800000"&gt;"</span><span style="color: #800000"&gt;worker1</span><span style="color: #800000"&gt;"</span><span style="color: #000000"&gt; } steps { timestamps { </span><span style="color: #0000ff"&gt;echo</span> <span style="color: #800000"&gt;'</span><span style="color: #800000"&gt;这是最后一个被执行的 stage.</span><span style="color: #800000"&gt;'</span><span style="color: #000000"&gt; } } } }

}

》一文中进行了介绍。到今年(2018) 7 月份声明式 pipeline 发布了版本 1.3,这个版本中开始支持本文介绍的任务流级别的并行。至此笔者认为 jenkins 声明式 pipeline 中任务的并行执行功能已经比较完善了。

(declarative pipeline 1.3 的新功能)

相关文章

基础环境、流程图1)流程图jenkinspipeline发布应用2)、jenki...
本节是建立在流水线入门内容的基础上,而且,应当被当作一个...
Linuxcentos7安装Jenkins(jenkins-2.227-1.1.noarch.rpm)时遇...
作为一个拥有很多账号的当代美少女,忘记用户名密码什么的是...
Jenkins、GitLab和Maven(Nexus)完成自动构建迈向持续集成持...
 下载文档https://www.jenkins.io/zh/download/  Debian下...