Running stages in parallel with Jenkins workflow / pipeline

匿名 (未验证) 提交于 2019-12-03 01:58:03

问题:

Please note: the question is based on the old, now called "scripted" pipeline format. When using "declarative pipelines", parallel blocks can be nested inside of stage blocks (see Parallel stages with Declarative Pipeline 1.2).

I'm wondering how parallel steps are supposed to work with Jenkins workflow/pipeline plugin, esp. how to mix them with build stages. I know about the general pattern:

parallel(firstTask: {   // Do some stuff }, secondTask: {   // Do some other stuff in parallel }) 

However, I'd like to run couple of stages in parallel (on the same node, which has multiple executors), so I tried to add stages like this:

stage 'A' // Do some preparation stuff  parallel(firstTask: {   stage 'B1'   // Do some stuff }, secondTask: {   stage 'B2'   // Do some other stuff in parallel })  stage 'C' // Finalizing stuff 

This does not work as expected. The "do stuff" tasks are executed in parallel, but the parallel stages end immediately and do not incorporate the stuff they should contain. As a consequence, the Stage View does not show the correct result and also does not link the logs.

Can I build different stages in parallel, or is the "parallel" step only meant to be used within a single stage?

回答1:

You may not place the deprecated non-block-scoped stage (as in the original question) inside parallel.

As of JENKINS-26107, stage takes a block argument. You may put parallel inside stage or stage inside parallel or stage inside stage etc. However visualizations of the build are not guaranteed to support all nestings; in particular

  • The built-in Pipeline Steps (a “tree table” listing every step run by the build) shows arbitrary stage nesting.
  • The Pipeline Stage View plugin will currently only display a linear list of stages, in the order they started, regardless of nesting structure.
  • Blue Ocean will display top-level stages, plus parallel branches inside a top-level stage, but currently no more.

JENKINS-27394, if implemented, would display arbitrarily nested stages.



回答2:

that syntax is now deprecated, you will get this error:

org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed: WorkflowScript: 14: Expected a stage @ line 14, column 9.        parallel firstTask: {        ^  WorkflowScript: 14: Stage does not have a name @ line 14, column 9.        parallel secondTask: {        ^  2 errors 

You should do something like:

stage("Parallel") {     steps {         parallel (             "firstTask" : {                 //do some stuff             },             "secondTask" : {                 // Do some other stuff in parallel             }         )     } } 


回答3:

I have just tested the following pipeline and it works

parallel firstBranch: {     stage ('Starting Test')      {         build job: 'test1', parameters: [string(name: 'Environment', value: "$env.Environment")]     } }, secondBranch: {     stage ('Starting Test2')      {         build job: 'test2', parameters: [string(name: 'Environment', value: "$env.Environment")]     } } 

This Job named 'trigger-test' accepts one parameter named 'Environment'

Job 'test1' and 'test2' are simple jobs:

Example for 'test1'

  • One parameter named 'Environment'
  • Pipeline : echo "$env.Environment-TEST1"

On execution, I am able to see both stages running in the same time



回答4:

I think this has been officially implemented now: https://jenkins.io/blog/2017/09/25/declarative-1/



回答5:

As @Quartz mentioned, you can do something like

stage('Tests') {     parallel(         'Unit Tests': {             container('node') {                 sh("npm test --cat=unit")             }         },         'API Tests': {             container('node') {                 sh("npm test --cat=acceptance")             }         }     ) } 


标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!