在Docker 1.1.2(最新版本)中,从容器中分离而不停止容器的正确方法是什么?

例如,如果我试着:

Docker运行-i -t foo /bin/bash或 Docker附加foo(用于已经运行的容器)

两者都把我带到集装箱中的一个终端,我如何在不停止它的情况下退出集装箱的终端?

exit和CTR+C都停止容器。


当前回答

如果你只想看到容器中运行的进程的输出,你可以做一个简单的docker container logs -f <容器id>。

使用-f标志可以实时跟踪和更新容器的输出。对于调试或监视非常有用。

其他回答

我深入研究了这个问题,上面所有的答案都部分正确。这完全取决于容器是如何启动的。当容器启动时,可以归结为:

分配了TTY (-t) stdin是否打开(-i)

^P^Q是有效的,但是只有当-t和-i被用来启动容器时:

[berto@g6]$ docker run -ti -d --name test python:3.6 /bin/bash -c 'while [ 1 ]; do sleep 30; done;'
b26e39632351192a9a1a00ea0c2f3e10729b6d3e22f8e0676d6519e15c08b518

[berto@g6]$ docker attach test
# here I typed ^P^Q
read escape sequence

# i'm back to my prompt
[berto@g6]$ docker kill test; docker rm -v test
test
test

ctrl+c可以工作,但是只有当使用-t(没有-i)来启动容器时:

[berto@g6]$ docker run -t -d --name test python:3.6 /bin/bash -c 'while [ 1 ]; do sleep 30; done;'
018a228c96d6bf2e73cccaefcf656b02753905b9a859f32e60bdf343bcbe834d

[berto@g6]$ docker attach test
^C

[berto@g6]$    

第三种方法

但是有一种方法可以在不杀死容器的情况下分离;你需要另一个外壳。总而言之,在另一个shell中运行这个命令会分离并让容器运行pkill -9 -f 'docker.*attach':

[berto@g6]$ docker run -d --name test python:3.6 /bin/bash -c 'while [ 1 ]; do sleep 30; done;'
b26e39632351192a9a1a00ea0c2f3e10729b6d3e22f8e0676d6519e15c08b518

[berto@g6]$ docker attach test
# here I typed ^P^Q and doesn't work
^P
# ctrl+c doesn't work either
^C
# can't background either
^Z

# go to another shell and run the `pkill` command above

# i'm back to my prompt
[berto@g6]$

为什么?因为您正在杀死连接到容器的进程,而不是容器本身。

当你运行docker attach时,你可以使用——detach-keys选项来覆盖默认的CTRL+P, CTRL+ Q序列(这并不总是有效)。

例如,当你运行docker attach——detach-keys=" CTRL - A " test并按下CTRL+A时,你将退出容器,而不会杀死它。

其他的例子:

docker attach——detach-keys=" CTRL - A,x" test -按CTRL+A,然后x退出 docker attach——detach-keys="a,b,c" test -按a,然后按b,然后按c退出

官方文件摘录:

如果你愿意,你可以为分离配置一个覆盖Docker密钥序列。如果Docker默认序列与用于其他应用程序的密钥序列冲突,这是有用的。有两种方法定义自己的分离键序列,作为每个容器的覆盖或作为整个配置上的配置属性。

要覆盖单个容器的序列,使用docker attach命令——detach-keys="<sequence>"标志。<序列>的格式可以是字母[a- z],也可以是ctrl-和以下任意组合:

a-z(一个小写字母) @(@号) [(左括号) \(两个反斜杠) _(下划线) ^(脱字符号)

这些a、ctrl-a、X或ctrl-\\值都是有效键序列的示例。若要为所有容器配置不同的配置默认密钥序列,请参阅配置文件部分。

注意:从docker版本1.10+开始工作(在回答这个问题时,当前版本是18.03)

为了防止有日志,您应该使用-d标志在分离模式下运行

docker run -d <your_command>

如果你已经卡住了,你可以在你的终端上打开一个新的窗口/标签,然后关闭第一个。它不会停止正在运行的作业的进程

在Docker容器中至少必须运行一个进程,然后只有容器将运行Docker映像(ubuntu,httd..等等,不管它是什么)在后台没有退出

例如,在ubuntu docker image中,

要创建一个带有分离模式的新容器(至少在进程上运行后台),

docker run -d -i -t f63181f19b2f /bin/bash

它将为这个映像(ubuntu)创建一个id为f63181f19b2f的新包含。容器将以分离模式运行(在后台运行),同时一个小进程tty bash shell将在后台运行。因此,容器将继续运行,直到bash shell进程被杀死。

若要附加到运行的后台容器,请使用

docker attach  b1a0873a8647

如果您想从容器中分离而不退出(不杀死bash shell), 默认情况下,您可以使用ctrl-p,q。它将从容器中出来而不退出容器(运行后台。这意味着不杀死bash shell)。

您可以在附加到容器时传递自定义命令,

docker attach --detach-keys="ctrl-s" b1a0873a8647

这一次,ctrl-p,q转义序列不起作用。相反,ctrl-s将用于从容器中退出。您可以传递任何键,例如,(ctrl-*)

旧帖子,但只是退出,然后重新开始…问题是,如果你是在windows机器上,Ctrl p或Ctrl p绑定打印…退出启动容器应该不会造成任何伤害