我天真地期望这个命令在一个正在运行的容器中运行bash shell:

docker run "id of running container" /bin/bash

看起来是不可能的,我得到了一个错误:

2013/07/27 20:00:24 Internal server error: 404 trying to fetch remote history for 27d757283842

因此,如果我想在运行容器中运行bash shell(例如用于诊断目的)

我必须在里面运行SSH服务器并通过SSH登录吗?


当前回答

首先,通过获取所需容器的容器id

docker ps

你会得到这样的结果:

CONTAINER ID        IMAGE                  COMMAND             CREATED             STATUS                          PORTS                    NAMES
3ac548b6b315        frontend_react-web     "npm run start"     48 seconds ago      Up 47 seconds                   0.0.0.0:3000->3000/tcp   frontend_react-web_1

现在复制这个容器id并运行以下命令:

docker exec -it container_id sh

docker exec -it 3ac548b6b315 sh

其他回答

编辑:现在你可以使用docker exec -它“运行容器的id”bash (doc)

之前,这个问题的答案是:

如果您确实必须这样做,并且处于调试环境中,您可以这样做:sudo lxc-attach -n <ID> 注意,id必须是完整的(docker ps -notrunc)。

然而,我强烈建议不要这样做。

注意:-notrunc已弃用,它将很快被——no-trunc取代。

实际上有一种方法可以让容器中有一个外壳。

假设您的/root/run.sh启动进程、进程管理器(管理器)或任何东西。

使用一些gnu屏幕技巧创建/root/runme.sh:

# Spawn a screen with two tabs
screen -AdmS 'main' /root/run.sh
screen -S 'main' -X screen bash -l
screen -r 'main'

现在,在tab 0中有守护进程,在tab 1中有交互式shell。Docker在任何时候附加,以查看容器内发生了什么。

另一个建议是使用所有必要的工具在产品映像之上创建一个“开发包”映像,包括这个屏幕技巧。

在运行容器时,分配名称是很有用的。您不需要引用container_id。

Docker运行——name container_name yourimage Docker exec -it container_name bash

不。这是不可能的。如果需要的话,可以使用类似于supervisor ord的工具来获取ssh服务器。不过,我对这种必要性表示怀疑。

只做

docker attach container_name

正如注释中提到的,要在不停止容器的情况下从容器中分离,请键入Ctrlpthen Ctrlq。