我注意到在使用Jenkins和Docker Pipeline插件时。当我创建一个Jenkins文件以在docker容器中运行命令时,它总是创建映射到正在运行的容器中相同路径的Jenkins工作空间目录的卷映射。它还会创建一个具有相同路径的工作目录。
docker run -t -d -u 127:134 -w /var/lib/jenkins/workspace/DockerTest
-v /var/lib/jenkins/workspace/DockerTest:/var/lib/jenkins/workspace/DockerTest:rw,z
-v /var/lib/jenkins/workspace/DockerTest@tmp:/var/lib/jenkins/workspace/DockerTest@tmp:rw,z
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
jekyll/jekyll:builder cat
我尝试通过在我的Jenkins文件中为Docker提供参数来覆盖它:
pipeline {
agent {
docker {
image 'jekyll/jekyll:builder'
args '-v $HOME:/srv/jekyll -w /srv/jekyll'
}
}
stages {
stage('Test') {
steps {
sh 'cd /srv/jekyll && ls -l'
}
}
}
}
这似乎只是在Docker命令的选项之前,而workdir和volume mapping被默认设置覆盖:
docker run -t -d -u 127:134
-v $HOME:/srv/jekyll
-w /srv/jekyll
-w /var/lib/jenkins/workspace/DockerTest
-v /var/lib/jenkins/workspace/DockerTest:/var/lib/jenkins/workspace/DockerTest:rw,z
-v /var/lib/jenkins/workspace/DockerTest@tmp:/var/lib/jenkins/workspace/DockerTest@tmp:rw,z
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
-e ********
jekyll/jekyll:builder cat
有什么方法可以以任何方式覆盖卷映射和工作目录?
答案 0 :(得分:0)
您可以将docker {}
与dir {}
结合使用以控制工作目录:
pipeline {
agent {
docker {
image 'jekyll/jekyll:builder'
args '-v $HOME:/srv/jekyll'
}
}
stages {
stage('Test') {
steps {
dir(path: '/srv/jekyll') {
sh 'ls -l'
}
}
}
}
}
我删除了-w
参数,因为它没有效果,并用cd /src/jekyll
替换了dir(path: '/srv/jekyll'){...}
答案 1 :(得分:0)
我们有一个相同的要求,即使用工作目录与容器中的默认目录不同,在检查了工作目录之后,到目前为止它是不可能的。在此处查看更多详细信息JENKINS-41474,JENKINS-35406,JENKINS-33510
另一种方法是使用dir("path_to_work") { sh ' '}
,但也没有用。
因此,唯一的方法是使用args
将卷装入容器并在其中运行带有change directory命令的所有命令
pipeline {
agent {
docker {
image 'alpine:3.7'
args '-v $HOME/src:/src'
}
}
stages {
stage('Build') {
steps {
sh 'cd /src ; ./run_build.sh'
}
}
}
}
答案 2 :(得分:-1)
我有一个类似的问题,问题不在于工作目录,因为我使用ENV变量从任何地方访问我的二进制文件。
我的问题是权限问题,即使我没有看到任何有关权限的错误消息。只需以root用户身份执行命令,看看是否有效,例如:
pipeline {
agent {
docker {
image 'jekyll/jekyll:builder'
args '-v $HOME:/srv/jekyll -w /srv/jekyll -u root'
}
}
stages {
stage('Test') {
steps {
sh 'cd /srv/jekyll && ls -l'
}
}
}
}