我一直在尝试在Jenkins声明式管道中运行特权容器,但我无法在文档中找到语法或任何示例。到目前为止,我拥有一个没有特权的容器:
pipeline {
agent none
stages {
stage("Build") {
agent {
docker { image "hello-world" }
}
}
}
}
似乎是一个普通的用例,我不敢相信没有人遇到过:(
最佳答案
请参考以下示例:
stage('Update dependencies version') {
agent {
docker {
image 'maven'
args '--privileged -v $HOME/.m2:/home/jenkins/.m2 -ti -u 496 -e MAVEN_CONFIG=/home/jenkins/.m2 -e MAVEN_OPTS=-Xmx2048m'
}
}
when {
not {
branch 'master'
}
}
steps {
script {
....
}
}
}
或在最高层:
pipeline {
agent {
docker {
image 'maven'
args '--privileged -v $HOME/.m2:/home/jenkins/.m2 -ti -u 496 -e MAVEN_CONFIG=/home/jenkins/.m2 -e MAVEN_OPTS=-Xmx2048m'
}
}
stages {
stage('Build') {
steps {
script {
maven.cleanPackage()
}
}
}
}
}
或在阶段脚本中:
stage('Build') {
agent {
label 'jenkins-slave-swat-prod-01'
}
steps {
script {
docker.image('mysql:latest').withRun('-e "MYSQL_ROOT_PASSWORD=password" -e "MYSQL_DATABASE=scheduler" -p 3306:3306') { c ->
docker.image('maven').inside("--privileged -v $HOME/.m2:/home/jenkins/.m2 -ti -u 496 -e MAVEN_CONFIG=/home/jenkins/.m2 -e MAVEN_OPTS=-Xmx2048m --link ${c.id}:localhost") {
maven.cleanPackage()
}
}
}
}
}
关于docker - 如何使用Jenkins声明式管道运行特权Docker容器,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/52409836/