我开始使用 Docker。我正在使用 WordPress 基础镜像和 docker-compose。
我正在尝试 ssh 进入其中一个容器以检查在初始构建期间创建的文件/目录。我试图运行docker-compose run containername ls -la,但这并没有做任何事情。即使是这样,我也宁愿有一个可以遍历目录结构的控制台,而不是运行单个命令。使用 Docker 执行此操作的正确方法是什么?
docker-compose run containername ls -la
docker attach将允许您连接到 Docker 容器,但这与ssh. 例如,如果您的容器正在运行网络服务器,docker attach则可能会将您连接到网络服务器进程的标准输出。它不一定会给你一个外壳。
docker attach
ssh
该docker exec命令可能是您正在寻找的;这将允许您在现有容器内运行任意命令。例如:
docker exec
docker exec -it <mycontainer> bash
当然,您运行的任何命令都必须存在于容器文件系统中。
在上面的命令<mycontainer>中是目标容器的名称或 ID。不管你是否使用docker compose; 只需运行docker ps并使用 ID(显示在第一列中的十六进制字符串)或名称(显示在最后一列中)。例如,给定:
<mycontainer>
docker compose
docker ps
$ 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 $