2016-04-29 57 views
5

在编写Jenkins管道脚本时,访问并行步骤中的变量是否安全?这个文件不清楚。使用Jenkins管道脚本,从并行步骤访问全局变量是否安全?

例如,这条管道的代码修改从并行分支共同计数器和队列:

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" 

回答

2

在当前实现,这可能是安全的,在管道执行使用合作多任务(也称为“绿线程”)。但我不确定,例如,+=是Groovy中的一个原子操作,其粒度在此处非常重要。更好地发挥它的安全性并使用标准的Java并发实用程序:ConcurrentLinkedQueue,AtomicInteger等。