如何进入Docker容器的shell?

docker docker-container


我正在开始使用Docker工作。我正在使用WordPress的基础图片和docker-compose。

我正在尝试使用ssh进入其中一个容器,以检查在初始构建期间创建的文件/目录。我试图运行 docker-compose run containername ls -la ,但是没有做任何事情。即使这样做,我还是希望有一个可以遍历目录结构的控制台,而不是运行单个命令。用Docker执行此操作的正确方法是什么?




Answer 1 larsks


docker attach 将允许您连接到Docker容器,但这与 ssh 并不是一回事。例如,如果您的容器正在运行Web服务器,则 docker attach 可能会将您连接到Web服务器进程的标准输出。它不一定会给您外壳。

docker exec 命令可能是你在找什么; 这将使您可以在现有容器中运行任意命令。例如:

docker exec -it <mycontainer> bash

当然,无论你运行的是什么命令,都必须存在于容器文件系统中。

在上面的命令中, <mycontainer> 是目标容器的名称或ID。无论您是否使用 docker compose 都不重要;只需运行 docker ps 并使用ID(显示在第一列中的十六进制字符串)或名称(显示在最后一列中)即可。例如,给定:

$ docker ps
d2d4a89aaee9        larsks/mini-httpd   "mini_httpd -d /cont   7 days ago          Up 7 days                               web                 

我可以跑。

$ docker exec -it web ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
18: eth0: <BROADCAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP 
    link/ether 02:42:ac:11:00:03 brd ff:ff:ff:ff:ff:ff
    inet 172.17.0.3/16 scope global eth0
       valid_lft forever preferred_lft forever
    inet6 fe80::42:acff:fe11:3/64 scope link 
       valid_lft forever preferred_lft forever

我可以通过跑步完成同样的事情。

$ docker exec -it d2d4a89aaee9 ip addr

同理,我可以在容器中启动一个壳。

$ docker exec -it web sh
/ # echo This is inside the container.
This is inside the container.
/ # exit
$



Answer 2 Agustí Sánchez


要在一个运行中的容器中进行撞击,请输入这个。

docker exec -t -i container_name /bin/bash

or

docker exec -ti container_name /bin/bash

or

docker exec -ti container_name sh



Answer 3 nobar


假设说,由于自己的原因,你真的想使用SSH。这需要一些步骤,但可以做到。以下是你在容器内运行的命令,以设置它.....

apt-get update
apt-get install openssh-server

mkdir /var/run/sshd
chmod 0755 /var/run/sshd
/usr/sbin/sshd

useradd --create-home --shell /bin/bash --groups sudo username ## includes 'sudo'
passwd username ## Enter a password

apt-get install x11-apps ## X11 demo applications (optional)
ifconfig | awk '/inet addr/{print substr($2,6)}' ## Display IP address (optional)

现在你甚至可以使用X11转发到SSH客户端运行图形化的应用程序(如果它们安装在容器中)。

ssh -X username@IPADDRESS
xeyes ## run an X11 demo app in the client

以下是一些相关资源。




Answer 4 bcmcfc


如果你像我一样在这里寻找Docker Compose特定的答案,它提供了一个简单的方法,无需查找生成的容器ID。

docker-compose exec 按照 docker-compose.yml 文件获取服务的名称。

因此,要为你的 "web "服务获得一个Bash shell,你可以这样做。

$ docker-compose exec web bash



Answer 5 Jeroen Peeters


注意:此答案将促进我编写的工具。

我创建了一个容器化的SSH服务器,你可以将其 "粘在任何运行中的容器上。这样你就可以用每一个容器来创建组合。唯一的要求是容器必须有Bash。

下面的例子将启动一个SSH服务器,该服务器连接到一个名为 "my-container "的容器上。

docker run -d -p 2222:22 \
  -v /var/run/docker.sock:/var/run/docker.sock \
  -e CONTAINER=my-container -e AUTH_MECHANISM=noAuth \
  jeroenpeeters/docker-ssh

ssh localhost -p 2222

当你连接到这个SSH服务时(用你所选择的SSH客户端),一个名为'my-container'的容器中的Bash会话将被启动。

有关更多指针和文档,请参见:https : //github.com/jeroenpeeters/docker-ssh