用例:我有5个要构建的对接映像,然后执行push命令。我希望这5张图片并行构建,当它们完成时,推到对接枢纽。
类似于:
docker build -t "wblankenship/test:1" ./test1 &
docker build -t "wblankenship/test:2" ./test2 &
docker build -t "wblankenship/test:3" ./test3 &
docker build -t "wblankenship/test:4" ./test4 &
docker build -t "wblankenship/test:5" ./test5 &
// Wait here for the previous 5 commands to finish
docker push wblankenship/test
这个是可能的吗?
发布于 2014-07-19 18:49:48
结果发现解决办法很简单。我用的是gnu并行。
最终产品如下:
parallel "docker build -t crackerz/nodejs:{} $DIR/dist/{} 2>&1 | tee ./logs/{}.log" ::: wheezy jessie sid precise saucy trusty
docker push crackerz/nodejs 2>&1 | tee ./logs/push.log
发布于 2014-07-19 18:30:18
只需使用wait
process &
process &
process &
wait
在没有参数的情况下,它等待所有后台进程完成。它使用PID等待特定的进程。
发布于 2014-07-19 19:47:14
如果您有GNU,xargs
可以尝试下一个:
seq 5 | xargs -P0 -i -n1 echo docker build -t "wblankenship/test:{}" ./test{} ; wait
以上如果为“试运行”,当您满足于正常执行时,请删除echo
。
以下方面:
-P0 mean - run the commands as many times is possible in background
wait
会..。嗯..。等。:)
https://stackoverflow.com/questions/24843570
复制相似问题