我已经尝试了一段时间,以在Jenkins声明式管道中运行特权容器,但是我在文档中找不到语法或任何示例。到目前为止,我拥有一个没有特权的容器:
pipeline {
agent none
stages {
stage("Build") {
agent {
docker { image "hello-world" }
}
}
}
}
这似乎是一个常见的用例,我不敢相信没有人会遇到它:(
答案 0 :(得分:2)
请参考以下示例:
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()
}
}
}
}
}