国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 服務器 > Dns服務器 > 正文

Docker 默認bridge網絡中配置DNS的方法

2024-09-08 23:25:49
字體:
來源:轉載
供稿:網友

本節描述如何在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及以上版本創建的容器才能使用此自動更新功能。

原文
https://docs.docker.com/engine/userguide/networking/default_network/configure-dns/

拓展閱讀
Docker存儲驅動的選擇:https://docs.docker.com/engine/userguide/storagedriver/selectadriver/#docker-ce

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到服務器教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 边坝县| 陆良县| 双流县| 随州市| 白山市| 普兰店市| 和平区| 资中县| 若尔盖县| 宜兴市| 绥化市| 南漳县| 凌云县| 鲁山县| 乌兰浩特市| 千阳县| 修武县| 灌云县| 正镶白旗| 鹤庆县| 黑山县| 双流县| 斗六市| 崇阳县| 西和县| 文成县| 灵武市| 明溪县| 马山县| 双江| 临湘市| 喀喇| 茌平县| 德庆县| 德兴市| 鄂伦春自治旗| 庆元县| 武定县| 陆良县| 昭觉县| 泸水县|