Environment
-
CloudBees CI (CloudBees Core) on modern cloud platforms - Managed controller
-
CloudBees CI (CloudBees Core) on traditional platforms - Client controller
-
CloudBees Jenkins Enterprise - Managed controller
Resolution
You need to use the parallel
directive.
The directive takes a map of String and Closure.
The string is the display name of the parallel execution and the Closure the actual Pipeline code you wish to execute.
Here are two examples to get you started:
def tasks = [:] tasks["task_1"] = { stage ("task_1"){ node('label_example1') { sh 'echo $NODE_NAME' } } } tasks["task_2"] = { stage ("task_2"){ node('label_example2') { sh 'echo $NODE_NAME' } } } parallel tasks
def testList = ["a", "b", "c", "d"] def branches = [:] for (int i = 0; i < 4 ; i++) { int index=i, branch = i+1 stage ("branch_${branch}"){ branches["branch_${branch}"] = { node ('label_example'){ sh "echo 'node: ${NODE_NAME}, index: ${index}, i: ${i}, testListVal: " + testList[index] + "'" } } } } parallel branches
In case you are doing declarative Pipeline, make sure to review its documentation.
This article is part of our Knowledge Base and is provided for guidance-based purposes only. The solutions or workarounds described here are not officially supported by CloudBees and may not be applicable in all environments. Use at your own discretion, and test changes in a safe environment before applying them to production systems.