запуск одной и той же задачи на нескольких агентах в моем декларативном конвейере Jenkins - PullRequest
0 голосов
/ 31 мая 2018

У меня есть блок вроде:

stage('Clone on win10x64-b-ut') {
    agent {
        node {
            label 'win10x64-b-ut'
        }
    }
    steps {
        gitClone()
    }
}    

stage('Clone on win81x64-b-ut') {
    agent {
        node {
            label 'win81x64-b-ut'
        }
    }
    steps {
        gitClone()
    }
}

Я хочу выполнить ту же задачу в виде цикла, просто меняя метки.Я хочу максимально устранить избыточность.

Ответы [ 2 ]

0 голосов
/ 05 февраля 2019

Принятый ответ не работает.Особенно в части определения.

Это работает:

def generateStage(nodeLabel) {
    stage("Runs on ${nodeLabel}") {
        node(nodeLabel) {
            sh 'hostname'
        }
    }
}

pipeline {
    agent {
        node {
            label '!docker'
        }
    }
    stages {
        stage('Run') {
            steps {
                script {
                    nodes = nodesByLabel(label: 'docker')

                    for (node in nodes) {
                        generateStage(node)
                    }
                }
            }
        }
    }
}
0 голосов
/ 01 июня 2018

Посмотрите на этот ответ: https://stackoverflow.com/a/48421660/9498358

Если вы не хотите запускать этапы параллельно (как в связанном ответе), вы можете добавить цикл for внутри блока скрипта, так чтоэто будет выглядеть примерно так:

def generateStage(nodeLabel) {
    return {
        stage("Clone on ${nodeLabel}") {
            agent {
                node {
                    label nodeLabel
                }
            }
            steps {
                gitClone()
            }
        } 
    }
}

// ...

stage('Clone') {
    steps {
        script {
            def allNodes = [win10x64-b-ut', 'win81x64-b-ut']

            for (def i = 0; i < allNodes[i]; i++) {
                generateStage(allNodes[i])
            }
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...