我正在Jenkinsfile中运行以下命令。然而,我收到错误“输入设备不是TTY”。

docker run -v $PWD:/foobar -it cloudfoundry/cflinuxfs2 /foobar/script.sh

有没有一种方法可以在不进行交互模式的情况下从Jenkinsfile运行脚本?

我基本上有一个名为script.sh的文件,我想在Docker容器中运行。


当前回答

只使用-i标志而不是-it标志。这可以帮助您了解容器内的情况。

docker exec -i $USER bash <<EOF
 apt install nano -y 
EOF

您可能会看到警告,但它显示了docker内部终端上的输出。

其他回答

同样的情况在这里,我运行以下命令throw.sh脚本(bash)和python.py然而,我得到了同样的错误“输入设备不是TTY”。

在我的例子中,我试图通过身份验证从“production”env的运行容器中获取转储,并传递一些参数,然后获取mssql数据库容器的.bak文件的输出。

从命令中删除-it。如果你想保持它的交互性,那么就保持-i。

您可以检查我的.sh文件和一个获取转储的长命令。

从cli中删除-it以使其非交互式,并删除TTY。如果您不需要,例如在Jenkins或cron脚本中运行命令,那么应该这样做。

或者,如果输入管道连接到docker命令,而不是来自TTY,则可以将其更改为-i。如果你有类似xyz|docker的东西。。。或码头工人<在命令行中输入,执行此操作。

或者,如果您希望TTY支持,但输入设备上没有TTY,则可以将其更改为-t。对于检查TTY以启用日志中输出的颜色格式的应用程序,或者当您稍后使用适当的终端连接到容器时,请执行此操作。

或者,如果您需要一个交互式终端,而不是在Linux或MacOS上的终端上运行,请使用不同的命令行界面。据报告,PowerShell在Windows上包含此支持。


什么是TTY?这是一个终端界面,支持转义序列、移动光标等,这源于以前连接到大型机的哑终端。今天,它由Linux命令终端和ssh接口提供。有关详细信息,请参阅维基百科文章。

要了解使用和不使用TTY运行容器的区别,请运行没有TTY的容器:docker run--rm-i ubuntu bash。从容器内部,安装带有apt-get-update的vim;apt-get安装vim。注意缺少提示。当对文件运行vim时,尝试在文件内移动光标。

对于那些在Windows上遇到这个错误和gitbash的人来说,只需使用PowerShell,它就可以完美地工作了。

为了让docker分配TTY(-t选项),当docker运行被调用时,您已经需要在TTY中。Jenkins不在TTY中执行其任务。

话虽如此,您在Jenkins中运行的脚本可能也希望在本地运行。在这种情况下,分配TTY非常方便,这样在本地运行时就可以发送类似ctrl+c的信号。

要解决此问题,请使脚本可以选择使用-t选项,如下所示:

test -t 1 && USE_TTY="-t" 
docker run ${USE_TTY} ...

如果使用windows,请尝试使用cmd,对我来说它是有效的。检查docker是否已启动。