我正在jenkins中设置自动构建和部署作业
现在,我有一个单独的阶段,并行任务设置如下
stage ('Testing & documenting'){
steps {
parallel (
"PHPLOC" : {
echo "Running phploc"
sh "./src/vendor/phploc/phploc/phploc --exclude=./src/vendor --no-interaction --quiet --log-csv=./build/logs/loc.csv src tests"
},
"SLOC": {
echo "Running sloc"
sh "sloccount --duplicates --wide --details . > ./build/logs/sloccount.sc 2>/dev/null"
},
"CPD" : {
echo "Running copy-paste detection"
sh "./src/vendor/sebastian/phpcpd/phpcpd --fuzzy . --exclude src/vendor --log-pmd ./build/logs/phpcpd.xml || true"
},
"MD" : {
echo "Running mess detection on code"
sh "./src/vendor/phpmd/phpmd/src/bin/phpmd src xml phpmd_ruleset.xml --reportfile ./build/logs/phpmd_code.xml --exclude vendor,build --ignore-violations-on-exit --suffixes php"
},
"PHPUNIT" : {
echo "Running PHPUnit w/o code coverage"
sh "./src/vendor/phpunit/phpunit/phpunit --configuration phpunit-quick.xml"
}
)
}
}在阅读了https://jenkins.io/blog/2018/07/02/whats-new-declarative-piepline-13x-sequential-stages/之后,我注意到它们使用了不同的结构。
stage("Documenting and Testing") {
parallel {
stage("Documenting") {
agent any
stages {
stage("CPD") {
steps {
//CPD
}
}
stage("PMD") {
steps {
//PMD stuff
}
}
}
stage("Testing") {
agent any
stages {
stage("PHPUnit") {
steps {
//PHPUnit
}
}
}
}我不确定这两种方法之间的区别是什么
发布于 2019-09-07 18:36:00
在steps块中运行parallel的第一个示例是由声明性管道的早期版本引入的。这有一些缺点。例如,要在不同的代理上运行每个parallel分支,您需要使用node步骤,如果这样做,parallel分支的输出将不能用于post指令(在阶段或管道级别)。基本上,旧的parallel步骤要求您在声明性管道中使用脚本管道。
第二个例子是为了克服前者的缺点而引入的真正的声明性语法。此外,此特定示例在并行阶段“记录”中运行两个串行阶段。
您可以阅读此官方博客以了解有关parallel指令https://jenkins.io/blog/2017/09/25/declarative-1/的更多信息。
https://stackoverflow.com/questions/57832501
复制相似问题