10

我尝试并行化动态定义的函数集,如下所示:

def somefunc() {
    echo 'echo1'
}

def somefunc2() {
    echo 'echo2'
}

running_set = [
    { somefunc() },
    { somefunc2() }
]

pipeline {
    agent none
    stages{
        stage('Run') {
            steps {
                parallel(running_set)                
            }

        }
    }
}

我最终得到的是:

org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed:
WorkflowScript: 17: No "steps" or "parallel" to execute within stage "Run" @ line 17, column 9.
           stage('Run') {

尽管步骤是在“运行”阶段定义的。无论如何,我想要实现的是一组动态定义的并行执行的函数。

4

2 回答 2

24

如果您想使用带有声明性管道脚本的动态并行块,您必须对 Jenkinsfile 应用两个更改:

  1. 您必须定义running_setMaplike ["task 1": { somefunc()}, "task 2": { somefunc2() }]- 此映射中的键用作并行阶段名称
  2. 您必须传递running_set给块parallel内的方法script {}

以下是更新后的 Jenkinsfile 的样子:

def somefunc() {
    echo 'echo1'
}

def somefunc2() {
    echo 'echo2'
}

running_set = [
    "task1": {
        somefunc()
    },
    "task2": {
        somefunc2()
    }
]

pipeline {
    agent none
    stages{
        stage('Run') {
            steps {
                script {
                    parallel(running_set)
                }
            }
        }
    }
}

这是 Blue Ocean UI 中的样子:

在此处输入图像描述

于 2018-04-10T13:09:49.810 回答
1

这并不明显。但 Szymon 的方式可能非常简单。

pipeline {
    agent none
    stages{
        stage('Run') {
            steps {
                script {
                    parallel([
                        'parallelTask1_Name': {
                            any code you like
                        },
                        'parallelTask2_Name': {
                            any other code you like
                        },
                        ... etc
                    ])
                }
            }
        }
    }
}
于 2019-11-07T15:22:14.800 回答