Jenkins shell脚本意外结束文件

时间:2018-06-14 08:37:02

标签: shell docker jenkins jenkins-pipeline

我使用Jenkins以下列方式启动了一个新的Docker服务器:

$ docker run -p 8081:8080 -p 50000:50000 -v "${PWD}"/jenkins:/var/jenkins_home -v /var/run/docker.sock:/var/run/docker.sock -d --name jenkins jenkins/jenkins:lts

我想将它用于执行构建另一个Docker容器的shell脚本的简单管道。这就是我加载docker.sock的原因。但是,使用如下所示的Jenkins文件:

pipeline {
    agent any

    stages {
        stage('Build') {
            steps {
                echo "####### builds: #######"
                sh "(exit 1) || true # whatever I write here, it always fails"
            }
        }
    }
}

我总是收到如下错误:

Print Message -- ####### builds: ####### -- (self time 7ms)
####### builds: ####### 

Shell Script -- (exit 1) || true -- (self time 18s)
[X's Pipeline] Running shell script sh: 1: Syntax error: end of file unexpected (expecting "done")
process apparently never started in /var/jenkins_home/workspace/X's Pipeline@tmp/durable-f294beff 

通过以下任何一行替换sh行确实会产生类似的错误消息,并导致构建过程失败:

  • sh "pwd;"
  • sh "echo 'hello';"
  • sh ./build.sh;"
  • sh ```
    #!/bin/sh
    echo hello
    ```
    
  • ...我尝试了更多

但是当我删除sh行时,构建成功。 我之前在其他系统上成功完成了这项工作。这里有什么我想念的吗?

  Operating System: CentOS Linux 7 (Core)
       CPE OS Name: cpe:/o:centos:centos:7
            Kernel: Linux 3.10.0-514.26.2.el7.x86_64
      Architecture: x86-64

    Docker version: 17.05.0-ce, build 89658be

1 个答案:

答案 0 :(得分:8)

事实证明,管道X's Pipeline的名称有';在使用GUI !!!!!! 时,Jenkins没有逃避它或警告用户。将管道重命名为X Pipeline后,工作正常。之前知道这一点可以节省我几个小时的麻烦......