王怡君
在日常使用Docker構(gòu)建微服務(wù)架構(gòu)的過程中,我們經(jīng)常會遇到一個問題:多個容器之間是如何通過名字互相訪問的?DNS是怎么做到的?
從底層機(jī)制講清楚Docker的DNS系統(tǒng)
1.容器間通信的前提:同一個網(wǎng)絡(luò)
Docker默認(rèn)會創(chuàng)建一個叫bridge的網(wǎng)橋網(wǎng)絡(luò)。所有未指定網(wǎng)絡(luò)的容器,都會被分配到這個bridge網(wǎng)絡(luò)中。
在這個默認(rèn)網(wǎng)絡(luò)中,雖然每個容器都有一個獨(dú)立的IP地址,但要實現(xiàn)通過容器名訪問其他容器,就必須依賴Docker提供的DNS服務(wù)。
??注意:只有在用戶自定義的bridge網(wǎng)絡(luò)中,容器名解析才默認(rèn)開啟!默認(rèn)的bridge網(wǎng)絡(luò)不支持容器名解析!
2.Docker的內(nèi)置DNS是如何工作的?
Docker在每個容器啟動時,會將容器的/etc/resolv.conf文件指向一個特殊的DNS地址:127.0.0.11
這個地址并不是真的公網(wǎng)DNS,而是DockerDaemon內(nèi)置的DNS服務(wù)器。
這個DNS有以下作用:
解析外部域名(比如訪問百度、Google)
解析容器內(nèi)部服務(wù)名(比如web,db等容器名)
它的背后是Docker的embeddedDNSserver,工作機(jī)制大概如下:
1??容器發(fā)出DNS查詢請求(查某個服務(wù)名)
2??請求發(fā)到127.0.0.11(docker的內(nèi)部DNS)
3??DockerDNS根據(jù)網(wǎng)絡(luò)配置,找到對應(yīng)容器的IP地址
4??將結(jié)果返回給發(fā)起請求的容器
3.實驗驗證:容器名訪問是否生效?
我們創(chuàng)建一個自定義網(wǎng)絡(luò),并啟動兩個容器測試下
#創(chuàng)建一個自定義bridge網(wǎng)絡(luò)dockernetworkcreatemynet#啟動容器A,名字叫webdockerrun-it--rm--nameweb--networkmynetbusyboxsh#啟動容器B,在這個網(wǎng)絡(luò)中嘗試pingwebdockerrun-it--rm--networkmynetbusyboxsh
在B容器中輸入:
pingweb
你會發(fā)現(xiàn),DNS能自動解析出web的IP,這就說明Docker的內(nèi)置DNS正常工作啦
4.自定義服務(wù)名(別名)怎么設(shè)置?
有時候我們希望容器訪問的名字不是容器名,而是我們指定的服務(wù)名。Docker也支持這一點(diǎn):
dockerrun-it--rm\--networkmynet\--namemydb\--network-aliasdatabase\busyboxsh
然后在其他容器中,就可以通過database這個名字訪問它
5.與外部DNS的協(xié)同
Docker的embeddedDNS并不是萬能的,它在無法解析服務(wù)名時,會把請求轉(zhuǎn)發(fā)給/etc/resolv.conf中指定的上游DNS。
這意味著:
外部網(wǎng)絡(luò)訪問正常(比如你容器內(nèi)pingwww.baidu.com)
內(nèi)部容器名也能解析
DockerDNS是中間層代理
這個設(shè)計非常巧妙!兼顧了內(nèi)外網(wǎng)的域名解析。
6.容器DNS失效的常見問題
?沒有使用自定義網(wǎng)絡(luò),導(dǎo)致DNS解析失敗
?使用了host網(wǎng)絡(luò),容器直接共享宿主機(jī)網(wǎng)絡(luò),無法使用Docker的DNS
?被resolv.conf修改或者掛載了宿主機(jī)DNS文件
?某些VPN環(huán)境導(dǎo)致容器DNS路由異常
解決方法建議:
盡量使用自定義bridge網(wǎng)絡(luò)
檢查/etc/resolv.conf是否被覆蓋
檢查Docker網(wǎng)絡(luò)配置dockernetworkinspect
總結(jié)
Docker容器之間的DNS解析,其實是靠DockerDaemon內(nèi)置的DNS服務(wù)(監(jiān)聽在127.0.0.11)來實現(xiàn)的,它能讓容器通過服務(wù)名互相訪問,還支持alias、自定義網(wǎng)絡(luò)、多級域名等能力。
相愛相殺的使徒 DNF奧茲瑪和米歇爾的故事
14、消滅安圖恩使徒安圖恩意圖前往魔界,冒險家、帝國、天界聯(lián)手追蹤并阻止了按圖嫩,最終安圖恩死亡并形成了克洛諾斯島。15、消滅使徒盧克調(diào)查寂靜城時發(fā)現(xiàn)了盧克在暗中散布黑色噩夢意圖恢復(fù)力量,最終盧克被消滅,冒險家通過寂靜城登上魔界。登臨魔界16、伊希斯·普雷使徒普雷的陰暗面伊希斯以卵的形式落入魔界,佧修好了吧!
《地下城與勇士》dnf使徒都分別有誰?使徒的背景歷史介紹?
第七使徒:火焰吞噬者-安徒恩安徒恩團(tuán)隊模式是地下城里最成功的副本了,也是讓DNF本身并不怎么火的游戲一下子變成了TOP3,甚至在安徒恩的那幾年榮登TOP1_——。但是在安徒恩身上的故事就有一點(diǎn)頗多了——。安徒恩作為20人副本當(dāng)然難度是不可小覷的,更不用說各種待遇也絕對是很好的。安徒恩算是悲情的BOSS之一,只不過他相對以后面會介紹。
DNF史書:海博倫君王使徒盧克,大轉(zhuǎn)移的最大受害者
在游戲中出現(xiàn)的攻堅戰(zhàn)團(tuán)本故事也講述了各個使徒的故事,比如安圖恩、盧克、普雷、希洛克等——。在此前,《地下城與勇士》中一共有12個使徒,但是隨著希洛克副本的背景故事曝光,出現(xiàn)了第十三使徒,也就是大家最喜愛的賽麗亞-。在所有使徒中,赫爾德可以說是所有使徒相關(guān)事件的操縱者,也是天界、魔界遭受災(zāi)難的罪魁禍?zhǔn)住?
來源:紅網(wǎng)
作者:公詩翠
編輯:王彥志
本文為紅辣椒評論 原創(chuàng)文章,僅系作者個人觀點(diǎn),不代表紅網(wǎng)立場。轉(zhuǎn)載請附原文出處鏈接和本聲明。