​如何在Docker默认网桥中配置容器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及以上版本创建的容器才能使用此自动更新功能。

原创文章,作者:QYTTD,如若转载,请注明出处:http://www.wangzhanshi.com/n/13747.html

(0)
QYTTD的头像QYTTD
上一篇 2025年1月1日 17:04:40
下一篇 2025年1月1日 17:04:42

相关推荐

  • DNS缓存中毒怎么工作的

    DNS缓存中毒是一种网络攻击,它使您的计算机误以为它会到达正确的地址,但事实并非如此。攻击者使用DNS缓存中毒来劫持互联网流量并窃取用户凭据或个人数据。DNS缓存中毒攻击也称为DN…

    2025年1月1日
  • 如何获取站点的各类响应时间

    有时候为了测试网络情况,需要返回每个阶段的耗时时间,比如DNS解析耗时,建立连接所消耗的时间,从建立连接到准备传输所使用的时间,从建立连接到传输开始所使用的时间,整个过程耗时,下载…

    2025年1月1日
  • ubuntu怎么修改dns

    1.使用快捷键【Ctrl+Alt+T】打开终端。 2.输入以下命令打开配置文件。 sudo vim **/etc/netplan/00-installer-config.yaml*…

    DNS解析 2025年1月1日
  • Windows环境下dig工具的安装及使用

    Dig 工具全称为域名信息搜索器(DomainInformation Groper),能够显示详细的DNS查询过程,是一个非常强大的DNS故障诊断工具。一般Linux和Unix系统…

    2025年1月1日
  • Linux下DNS服务器架设步骤

    named 这个主体进程在启动时需要读取一个初始化文件,缺省为 /etc/named.boot。另外建议大家使用Linux自带的ndc工具来进行启动、中止、重启动、刷新DNS数据、…

    DNS解析 2025年1月1日
  • CM域名为什么不能解析和修改DNS

      联系ENOM官方得到的答案是:我们的技术支持人员一直无法找出这个问题的根源。因此,我们的开发团队的正在对细节做进一步研究。 然而,9天过去了,所有出现问题的域名还是无…

    2025年1月1日
  • DNS正向解析和主从复制脚本的过程

    #!/bin/bash#测试是否安装bind[ ! -f /etc/named.conf ] && echo "没有安装DNS服务,现在安装" …

    DNS解析 2025年1月1日
  • windows默认网关和dns如何设置

    默认网关和dns设置的详细教程 第一步:打开网络管理中心,选择以太网,点击更改适配器选项。 第二步:右击以太网(本地连接),选择属性。 第三步:找到协议版本4,双击。 第四步:把自…

    2025年1月1日
  • DNS主机记录也能用*

        在部署windows的RemoteAPP的时候,发现DNS查询会影响呼起客户端的速度,并且发布新的客户端,可能会出现新的查询,不可能…

    DNS解析 2025年1月1日
  • 如何搭建智能DNS

    智能DNS搭建方案 智能DNS主要通过用户源IP来判断来源,然后根据不同的策略解析到不同的IP地址来实现。使得用户可以就近访问所需的资源,提高访问速度,提升用户感知。 智能DNS可…

    DNS解析 2025年1月1日

发表回复

登录后才能评论