我遇到问题让Jenkins管道脚本工作,使用Docker Pipeline插件在Docker容器中运行部分构建。 Jenkins服务器和从服务器都在Docker容器中运行。
docker:1.12-dind
image docker run --link=docker-daemon:docker --link=jenkins:master -d --name protokube-jenkins-slave -e EXTRA_PARAMS="-username xxx -password xxx -labels docker" simulogics/protokube-jenkins-slave
基本的Docker操作(拉,构建和推送图像)可以正常使用此设置。
inside
函数。这是导致问题的代表性构建步骤:
image.inside {
stage ('Install Ruby Dependencies') {
sh "bundle install"
}
}
这会在日志中导致这样的错误:
sh:1:无法创建/ workspace / repo_branch-K5EM5XEVEIPSV2SZZUR337V7FG4BZXHD4VORYFYISRWIO3N6U67Q @ tmp / durable-98bb4c3d / pid:目录不存在
以前,此警告会显示:
71f4de289962-5790bfcc似乎在容器内运行71f4de28996233340c2aed4212248f1e73281f1cd7282a54a36ceeac8c65ec0a 但在[]
中找不到/ workspace / repo_branch-K5EM5XEVEIPSV2SZZUR337V7FG4BZXHD4VORYFYISRWIO3N6U67Q
有趣的是,这个插件的CloudBees文档中描述了这个问题https://go.cloudbees.com/docs/cloudbees-documentation/cje-user-guide/index.html#docker-workflow-sect-inside:
对于内部工作,Docker服务器和Jenkins代理必须使用相同的文件系统,以便可以安装工作区。确保这一点的最简单方法是让Docker服务器在localhost(与代理程序相同的计算机)上运行。目前,Jenkins插件和Docker CLI都不会自动检测服务器远程运行的情况;典型的症状是来自嵌套sh命令的错误,例如
无法创建/ ... @ tmp / durable- ... / pid:目录不存在 或否定退出代码。
当Jenkins可以检测到代理本身在Docker容器内运行时,它会自动将--volumes-from参数传递给内部容器,确保它可以与代理共享工作区。
不幸的是,最后一段中描述的检测似乎不起作用。
由于我的服务器和从服务器都在Docker容器中运行,我必须使用什么样的卷映射来使其工作?
答案 0 :(得分:1)
我已经看到了此问题的变体,agents
也提供了kubernetes-plugin
。
我认为要使它工作,agent/jnlp
容器需要与build
容器共享工作区。
通过build
容器,我指的是将运行bundle install
命令的容器。
这可能通过withArgs
问题是你为什么要那样做?无论如何,大多数管道步骤都在master上执行,实际构建将在build
容器中运行。使用agent
?