临时 #### docker DNS ========== 使用 docker DNS 的限制:: 只能在 user-defined 网络中使用。 默认的 bridge 网络是无法使用的。 如果两个容器一开始运行时处于不同的 user-defined 网络, 可以通过 docker network connect 命令添加另一个容器的网络 容器间访问 ========== 容器之间相互访问,需要两方面的支持:: 容器的网络拓扑是否已经互联。默认情况下,所有容器都会被连接到 docker0 网桥上。 本地系统的防火墙软件 -- iptables 是否允许通过。 访问所有端口:: 当启动 Docker 服务时候,默认会添加一条转发策略到 iptables 的 FORWARD 链上。 策略为通过(ACCEPT)还是禁止(DROP)取决于配置--icc=true(缺省值)还是 --icc=false。 当然,如果手动指定 --iptables=false 则不会添加 iptables 规则。 可见,默认情况下,不同容器之间是允许网络互通的。 如果为了安全考虑,可以在 /etc/default/docker 文件中配置 DOCKER_OPTS=--icc=false 来禁止它。 访问指定端口:: 在通过 -icc=false 关闭网络访问后,还可以通过 --link=CONTAINER_NAME:ALIAS 选项来访问容器的开放端口。 例如: 在启动 Docker 服务时,可以同时使用 ``icc=false --iptables=true`` 参数来 关闭允许相互的网络访问,并让 Docker 可以修改系统中的 iptables 规则。 此时,系统中的 iptables 规则可能是类似:: $ sudo iptables -nL ... Chain FORWARD (policy ACCEPT) target prot opt source destination DROP all -- 0.0.0.0/0 0.0.0.0/0 ... 当添加了 --link=CONTAINER_NAME:ALIAS 选项后,添加了 iptables 规则:: $ sudo iptables -nL ... Chain FORWARD (policy ACCEPT) target prot opt source destination ACCEPT tcp -- 172.17.0.2 172.17.0.3 tcp spt:80 ACCEPT tcp -- 172.17.0.3 172.17.0.2 tcp dpt:80 DROP all -- 0.0.0.0/0 0.0.0.0/0 映射容器端口到宿主主机的实现 ============================ 使用 -P 时(把80端口映射一个随机主机端口49153):: $ iptables -t nat -nL ... Chain DOCKER (2 references) target prot opt source destination DNAT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:49153 to:172.17.0.2:80 使用 -p 80:80 时(把80端口映射到主机的80端口):: $ iptables -t nat -nL Chain DOCKER (2 references) target prot opt source destination DNAT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:80 to:172.17.0.2:80