Docker 默认bridge网络中配置DNS的方法
本节描述如何在docker默认网桥中配置容器dns。 当您安装docker时,就会自动创建一个名为bridge 的桥接网络。
注意 : docker网络功能 允许您创建除默认网桥之外的用户自定义网络。 有关用户自定义网络中dns配置的更多信息,请参阅docker嵌入式dns 部分。
docker如何为每个容器提供主机名和dns配置,而无需在构建自定义docker镜像时在内部写入主机名?它的诀窍是利用可以写入新信息的虚拟文件,在容器内覆盖三个关键的/etc 文件。 你可以通过在一个容器中运行mount 来看到这一点:
root@f38c87f2a42d:/# mount ... /dev/disk/by-uuid/1fec...ebdf on /etc/hostname type ext4 ... /dev/disk/by-uuid/1fec...ebdf on /etc/hosts type ext4 ... /dev/disk/by-uuid/1fec...ebdf on /etc/resolv.conf type ext4 ... ...
这样一来,docker可以让宿主机在稍后通过dhcp接收到新的配置后,使所有容器中的resolv.conf 保持最新状态。 docker在容器中维护这些文件的具体细节可能会可能会随着docker版本的演进而改变,因此您不该自己管理/etc文件,而应该用以下docker选项。
四个不同的选项会影响容器域名服务。
参数 | 描述 |
---|---|
-h hostname or --hostname=hostname | 设置容器的主机名。 该设置的值将会被写入/etc/hostname ;写入/etc/hosts 作为容器的面向主机ip地址的名称(笔者按:在/etc/hosts里添加一条记录,ip是宿主机可以访问的ip,host就是你设置的host),并且是容器内部/bin/bash 在其提示符下显示的名称。 但主机名不容易从容器外面看到。 它不会出现在docker ps 或任何其他容器的/etc/hosts文件中。 |
--link=container_nameor id:alias | 在run 容器时使用此选项为新容器的/etc/hosts 添加了一个名为alias的额外条目,指向由container_name_or_id标识的container_name_or_id的ip地址。这使得新容器内的进程可以连接到主机名alias 而不必知道其ip。 --link=选项将在下面进行更详细的讨论。 因为docker可以在重新启动时为链接的容器分配不同的ip地址,docker会更新收件人容器的/etc/hosts 文件中的alias条目。 |
--dns=ip_address... | 在容器的/etc/resolv.conf文件添加nameserver 行,ip地址为指定ip。 容器中的进程在如果需要访问/etc/hosts 里的主机名,就会连接到这些ip地址的53端口,寻找名称解析服务。 |
--dns-search=domain... | 通过在容器的/etc/resolv.conf写入search 行,在容器内使用裸不合格的主机名时搜索的域名。 当容器进程尝试访问host 并且搜索域example.com 被设置时,例如,dns逻辑不仅将查找host ,还将查找host.example.com 。使用--dns-search=. 如果您不想设置搜索域。 |
--dns-opt=option... | 通过将options 行写入容器的/etc/resolv.conf 设置dns解析器使用的选项。有关有效选项的列表,请参阅resolv.conf文档 |
在没有--dns=ip_address... , --dns-search=domain...或--dns-opt=option...选项的情况下,docker使每个容器的/etc/resolv.conf 看起来像宿主机的/etc/resolv.conf 。当创建容器的/etc/resolv.conf ,docker daemon会从主机的原始文件中过滤掉所有localhost ip地址nameserver 条目。
过滤是必要的,因为主机上的所有localhost地址都不可从容器的网络中访问。 过滤之后,如果容器的/etc/resolv.conf 文件中没有更多的nameserver 条目,docker daemon会将google dns名称服务器(8.8.8.8和8.8.4.4)添加到容器的dns配置中。 如果守护进程启用了ipv6,则也会添加公共ipv6 google dns名称服务器(2001:4860:4860::8888 和 2001:4860:4860::8844)。
注意 :如果您需要访问主机的localhost解析器,则必须在主机上修改dns服务,以便侦听从容器内可访问的non-localhost地址。
您可能会想知道宿主机的/etc/resolv.conf 文件发生了什么变化。 docker daemon 有一个文件更改通知程序,它将监视主机dns配置的更改。
注意 :文件更改通知程序依赖于linux内核的inotify功能。由于此功能目前与overlay文件系统驱动不兼容,因此使用“overlay”的docker daemon将无法利用/etc/resolv.conf 自动更新的功能。
当宿主机文件更改时,所有resolv.conf 与主机匹配的停止的容器将立即更新到最新的主机配置。 当宿主机配置更改时,运行的容器将需要停止并开始接收主机更改,这是由于缺少设备,以确保在容器运行时对resolv.conf 文件的原子写入。 如果容器修改了默认的resolv.conf 文件,则不会替换该文件,因为如果替换,将会覆盖容器执行的更改。 如果选项( --dns , --dns-search 或--dns-opt )已被用于修改默认的主机配置,则更换主机的/etc/resolv.conf 也不会发生。
注意 :对于在docker 1.5.0中实现/etc/resolv.conf 更新功能之前创建的容器:当主机resolv.conf文件更改时,这些容器将不会收到更新。 只有使用docker 1.5.0及以上版本创建的容器才能使用此自动更新功能。
原文
拓展阅读
docker存储驱动的选择:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
Docker为网络bridge模式指定容器ip的方法
-
详解Docker中VLAN网络模式的配置
-
Tomcat中更改网站根目录和默认页的配置方法
-
为docker中的nginx配置https的方法步骤
-
VMware中安装Linux系统(Redhat8)及虚拟机的网络配置方法
-
在centos7 中docker info报错docker bridge-nf-call-iptables is disabled 的解决方法
-
docker中容器的网络配置常用命令详解
-
Docker 配置网络使用bridge网络的方法
-
Docker 默认bridge网络中配置DNS的方法
-
Ubuntu中静态DNS配置的方法详解