gpt4 book ai didi

java - 如何使用jenkins中的管道插件将参数传递给并行进程

转载 作者:行者123 更新时间:2023-11-30 06:50:44 24 4
gpt4 key购买 nike

我在 Jenkinsfile 中有以下代码。第 1 步:有值列表。第 2 步:将该列表传递给函数。步骤3:尝试将值动态传递给java jar。但值未正确分配。因为它在步骤(4)中进行分配,然后同时触发该过程(5)。

def numToEcho = [1,10,20,27] ---(1)

def stepsForParallel = [:]

for (int i = 0; i < numToEcho.size(); i++) {
def s = numToEcho.get(i)
def stepName = "echoing ${s}"

stepsForParallel[stepName] = transformIntoStep(s) --(4)
}
parallel stepsForParallel --(5)

def transformIntoStep(inputNum) { ---(2)
return {
node {
echo inputNum
def tb = sh script:' java -jar titanRead.jar $inputNum', returnStdout:true --(3)
}
}
}

现在我想将列表值传递给 jar。就像下面的并行过程一样。

Sh ‘java -jar TitanRead.jar 1’  
Sh ‘java -jar TitanRead.jar 10’
Sh ‘java -jar TitanRead.jar 20’
Sh ‘java -jar TitanRead.jar 27’

在 jar 内,我读的是 arg[0]..并且它抛出 ArrayIndexOutOfBoundException..但是如果我在终端中单独运行 jar,它正在工作..我该怎么做..请帮助我解决这个问题.

最佳答案

您问题中的管道似乎与您的描述不符,因为 java jar TitanRead.jar 无法工作;您需要使用-jar

无论如何,您的 sh script 参数应使用双引号字符串,否则 $inputNum 将不会被评估,即:

sh script: "java -jar TitanRead.jar ${inputNum}"

关于java - 如何使用jenkins中的管道插件将参数传递给并行进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42840842/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com