1

我在容器中运行的 Jenkins 中设置 CI 管道。我正在使用官方的 jenkins/jenkins:latest docker image,没有任何修改。在 Jenkins 本身上,我安装了 docker 插件,并在全局工具配置中添加了 docker 安装,并在管道工具部分添加了 dockerTool。

我使用以下命令创建了容器:

docker run -d -u root -p 8080:8080 -p 50000:50000 -v /var/run/docker.sock:/var/run/docker.sock -v jenkins_home:/var/jenkins_home jenkins/jenkins:latest

我安装了 docker.sock 以使用主机上的部分 docker 来构建图像。这是 Jenkinsfile 的一部分,但失败了:

stage('PUSH') {
        steps {
            script {
                dockerImage = docker.build 'mygithub/spring-petclinic:latest'
                docker.withRegistry( '', 'dockerHubCreds' ) {
                  dockerImage.push()
                }
            }
        }
    }

形象塑造成功。仅当我尝试将图像推送到 DockerHub 时,构建才会失败。它说没有这样的文件/目录称为 Docker,但上一步实际上打印了 docker build 命令。

我在下面提供了日志。

+ docker build -t qeqoos/spring-petclinic:latest .
Sending build context to Docker daemon  63.25MB

Step 1/4 : FROM openjdk:8-jre-alpine3.9
 ---> f7a292bbb70c
Step 2/4 : COPY target/spring-petclinic-2.5.0-SNAPSHOT.jar /usr/bin/spring-petclinic.jar
 ---> ced11038c9dd
Step 3/4 : EXPOSE 80
 ---> Running in f222a20aad19
Removing intermediate container f222a20aad19
 ---> 3cd6a16e7890
Step 4/4 : ENTRYPOINT ["java", "-jar", "/usr/bin/spring-petclinic.jar", "--server.port=80"]
 ---> Running in 0a392d01e56b
Removing intermediate container 0a392d01e56b
 ---> 9afe8b544a7b
Successfully built 9afe8b544a7b
Successfully tagged qeqoos/spring-petclinic:latest
[Pipeline] withEnv
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u qeqoos -p ******** https://index.docker.io/v1/
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // withEnv
[Pipeline] }
[Pipeline] // script
[Pipeline] }
[Pipeline] // withEnv
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // withEnv
[Pipeline] }
[Pipeline] // withEnv
[Pipeline] }
[Pipeline] // node
[Pipeline] End of Pipeline
java.io.IOException: error=2, No such file or directory
    at java.base/java.lang.ProcessImpl.forkAndExec(Native Method)
    at java.base/java.lang.ProcessImpl.<init>(ProcessImpl.java:340)
    at java.base/java.lang.ProcessImpl.start(ProcessImpl.java:271)
    at java.base/java.lang.ProcessBuilder.start(ProcessBuilder.java:1107)
Caused: java.io.IOException: Cannot run program "docker": error=2, No such file or directory
    at java.base/java.lang.ProcessBuilder.start(ProcessBuilder.java:1128)
    at java.base/java.lang.ProcessBuilder.start(ProcessBuilder.java:1071)
    at hudson.Proc$LocalProc.<init>(Proc.java:252)
    at hudson.Proc$LocalProc.<init>(Proc.java:221)
    at hudson.Launcher$LocalLauncher.launch(Launcher.java:995)
    at hudson.Launcher$ProcStarter.start(Launcher.java:507)
    at hudson.Launcher$ProcStarter.join(Launcher.java:518)
    at org.jenkinsci.plugins.docker.commons.impl.RegistryKeyMaterialFactory.materialize(RegistryKeyMaterialFactory.java:101)
    at org.jenkinsci.plugins.docker.workflow.AbstractEndpointStepExecution2.doStart(AbstractEndpointStepExecution2.java:53)
    at org.jenkinsci.plugins.workflow.steps.GeneralNonBlockingStepExecution.lambda$run$0(GeneralNonBlockingStepExecution.java:77)
    at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
    at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
    at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
    at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
    at java.base/java.lang.Thread.run(Thread.java:829)
Finished: FAILURE

对于容器中的詹金斯,有没有更好的方法,或者有什么建议如何让詹金斯推送图像?谢谢你。

4

1 回答 1

1

jenkins/jenkins:latest默认不会有docker client二进制,你只是挂载unix socket到容器,这肯定是不够的。

我认为输入command输出只是打印出来:它计划使用的 docker 命令是什么,并不意味着它已经运行它。

所以,对你来说,你需要在jenkins容器中安装 docker 客户端:

  • 要么使用绑定挂载:
docker run -v `which docker`:/usr/bin/docker ......
  • 或者,如果主机的 docker 客户端不适合容器环境,直接docker client这里docker下载 prebuilt,将二进制文件复制到容器中。
于 2021-10-15T14:37:06.037 回答