如何进入码头集装箱?
我正在开始与Docker合作。 我正在使用WordPress的基本形象和码头构成。 我试图ssh进入一个容器来检查在初始构建期间创建的文件/目录。 我试图运行docker-compose run containername ls -la
但没有做任何事情。 即使这样做,我宁愿有一个可以遍历目录结构的控制台,而不是运行一个命令。 用Docker做这件事的正确方法是什么?
docker attach
会让你连接到你的Docker容器,但这与ssh
并不是一回事。 例如,如果您的容器正在运行Web服务器,则docker attach
可能会将您连接到Web服务器进程的stdout。 它不一定会给你一个壳。
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
$
要打开正在运行的容器,请键入以下内容:
docker exec -t -i container_name /bin/bash
比方说,由于你自己的原因,你真的想使用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
以下是一些相关资源: