编写Jenkins Pipeline脚本时,从并行步骤访问变量是否安全?文档不清楚。
例如,此管道代码修改了并行分支中的公共计数器和队列:
def donecount = 0;
def work = [6,5,4,3,2,1,0]
def branches = [:]
for (int i = 0; i < 3; i++) {
branches["worker-${i}"] = {
while (true) {
def item = null
try {
item = work.remove(0)
} catch (java.lang.IndexOutOfBoundsException e) {
break
}
echo "Working for ${item} seconds"
sleep time:item
donecount += 1
}
}
}
branches.failFast = true
parallel branches
echo "Completed ${donecount} tasks"
答案 0 :(得分:2)
在当前的实现中,这可能是安全的,因为管道执行使用了协同式多任务处理(也称为“绿色线程”)。但我不确定,例如,+=
是Groovy中的原子操作,其粒度在这里很重要。最好安全地使用它并使用标准的Java并发实用程序:ConcurrentLinkedQueue
,AtomicInteger
等。