如何进入 Docker 容器的外壳?

新手上路,请多包涵

我开始使用 Docker。我正在使用 WordPress 基础镜像和 docker-compose。

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

原文由 Andrew 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 443
2 个回答

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

同样,我可以在容器中启动一个 shell;

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

原文由 larsks 发布,翻译遵循 CC BY-SA 4.0 许可协议

要 bash 进入正在运行的容器,请输入:

 docker exec -t -i container_name /bin/bash

或者

docker exec -ti container_name /bin/bash

或者

docker exec -ti container_name sh

原文由 Agustí Sánchez 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题