Jenkins   发布时间:2019-10-27  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Jenkins pipeline 并行执行任务流大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

{ stage({ ... } stage({ parallel { stage({ agent { label { { agent { label { { ... } }

title="jenkins pipeline 并行执行任务流" alt="jenkins pipeline 并行执行任务流" src="https://cn.js-code.com/res/2019/02-09/09/e7e04e4a0f288e263ccf37c6122c6630.png" >

title="jenkins pipeline 并行执行任务流" alt="jenkins pipeline 并行执行任务流" src="https://cn.js-code.com/res/2019/02-09/09/e50142d79a7d8319b1128a73f53a5e3e.png" >

{ agent none
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;
            }
        }
    }
}

}

timestamper 插件。下图显示了笔者精简后的运行日志:

title="jenkins pipeline 并行执行任务流" alt="jenkins pipeline 并行执行任务流" src="https://cn.js-code.com/res/2019/02-09/09/85e22da78b88703e209bc55374244525.png" >

jenkins 对声明式 pipeline 中并行任务的执行支持的非常给力(然经历了一个稍显漫长的过程)。笔者在 2017 年初调研时发现声明式 pipeline 无法支持并行的任务,后来开始支持比较初级的并行任务,笔者在《》一文中进行了介绍。到今年(2018) 7 月份声明式 pipeline 发布了版本 1.3,这个版本中开始支持本文介绍的任务流级别的并行。至此笔者认为 jenkins 声明式 pipeline 中任务的并行执行功能已经比较完善了。

(declarative pipeline 1.3 的新功能)

大佬总结

以上是大佬教程为你收集整理的Jenkins pipeline 并行执行任务流全部内容,希望文章能够帮你解决Jenkins pipeline 并行执行任务流所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: