我正在Jenkinsfile中运行以下命令。然而,我收到错误“输入设备不是TTY”。
docker run -v $PWD:/foobar -it cloudfoundry/cflinuxfs2 /foobar/script.sh
有没有一种方法可以在不进行交互模式的情况下从Jenkinsfile运行脚本?
我基本上有一个名为script.sh的文件,我想在Docker容器中运行。
我正在Jenkinsfile中运行以下命令。然而,我收到错误“输入设备不是TTY”。
docker run -v $PWD:/foobar -it cloudfoundry/cflinuxfs2 /foobar/script.sh
有没有一种方法可以在不进行交互模式的情况下从Jenkinsfile运行脚本?
我基本上有一个名为script.sh的文件,我想在Docker容器中运行。
当前回答
对于使用Pyinvoke的用户,请参阅以下文档,如果链接失效,我将在这里联合这些文档:
99%的情况下,将pty=True添加到您的跑步通话中会使事情按照您的预期进行。继续阅读原因(以及为什么pty=True不是默认值)。
命令行程序经常根据控制终端是否存在而改变行为;一个常见的例子是彩色输出的使用或废弃。当输出的接收者是终端上的人时,您可能需要使用颜色、调整线路长度以匹配终端宽度等。
相反,当您的输出被发送到另一个程序(shell管道、CI服务器、文件等)时,颜色转义码和其他特定于终端的行为可能会导致无用的垃圾。
Invoke的用例涵盖了以上两种情况——有时您只希望直接显示数据,有时您只想将其捕获为字符串;通常你都想要。因此,没有“正确”的默认行为:使用伪终端——无论哪种方式都会给大量用例带来不便。
对于不关心的用例,没有伪终端的直接调用更快、更干净,因此它是默认的。
其他回答
而不是使用-it使用--tty
所以你的docker运行应该是这样的:
docker run -v $PWD:/foobar --tty cloudfoundry/cflinuxfs2 /foobar/script.sh
对于使用Pyinvoke的用户,请参阅以下文档,如果链接失效,我将在这里联合这些文档:
99%的情况下,将pty=True添加到您的跑步通话中会使事情按照您的预期进行。继续阅读原因(以及为什么pty=True不是默认值)。
命令行程序经常根据控制终端是否存在而改变行为;一个常见的例子是彩色输出的使用或废弃。当输出的接收者是终端上的人时,您可能需要使用颜色、调整线路长度以匹配终端宽度等。
相反,当您的输出被发送到另一个程序(shell管道、CI服务器、文件等)时,颜色转义码和其他特定于终端的行为可能会导致无用的垃圾。
Invoke的用例涵盖了以上两种情况——有时您只希望直接显示数据,有时您只想将其捕获为字符串;通常你都想要。因此,没有“正确”的默认行为:使用伪终端——无论哪种方式都会给大量用例带来不便。
对于不关心的用例,没有伪终端的直接调用更快、更干净,因此它是默认的。
从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 compose exec-T通过Jenkins为我解决了这个问题
docker compose exec-T containerName php script.php