又到了招聘季了,前兩天遇到一個面試的小夥伴,他說面試官和他聊得很投機,無心中談到了DNS請求的過程。他一時語塞隨便應付了兩句,雖然對方沒有追問的意思,但最後面試結果也並不理想。本着邊面試邊學習的態度,咱們來看看DNS請求的過程當中涉及到的定義和原理。linux
衆所周知,在互聯網中是用IP來標識一臺服務器的。IP地址雖然可以表明一臺設備,可是因爲記憶起來比較困難,因此將其替換成一個可以理解和識別的名字,這個名字咱們稱做爲域名。例如:www.51cto.com 就是一個域名,在域名後面會定義一個IP地址用來指向網站服務器。那麼問題來了,誰來作這個從域名到IP地址的對應呢?答案是經過DNS來實現。web
DNS 是域名系統(Domain Name System,縮寫:DNS)是互聯網的一項服務。它將域名和IP地址相互映射的一個分佈式數據庫,在數據庫中保存域名與IP的對照關係,從而令人更方便地訪問互聯網。面試
DNS解析是分佈式存儲的,從結構上來講最頂層是,根域名服務器(ROOT DNS Server),存儲260個頂級域名服務器的IP地址。對於Ipv4來講全球有13個根域名服務器,它儲存了每一個域(如.com .net .cn)的解析和域名服務器的地址信息。簡單的說,根域名服務器就是存放頂級域名服務器地址的。數據庫
在根域名服務器下一級就是,頂級域名服務器。例如.com的域名服務器,存儲的是一些一級域名的權威DNS服務器地址(如toutiao.com的DNS)。windows
頂級域名又稱一級域名,頂級域名能夠分爲三類,即gTLD、ccTLD和New gTLD:瀏覽器
頂級域名服務器就是根據上面三類保存域名IP對應數據的。緩存
在頂級域名服務器下面一級就是,本地域名服務器(Local DNS)通常是運營商的DNS,主要做用就是代理用戶進行域名分析的。服務器
如圖1 所示,DNS域名服務器分爲三級,從上到下分別是根域名服務器(Root DNS Server)、頂級域名服務器(gTLD、ccTLD、New gTLD)、本地域名服務器(Local DNS Server)。網絡
圖1 DNS分層結構負載均衡
說完DNS的結構,再來談談其運行原理。經過用戶訪問網頁的過程,來描述DNS解析以及獲取URL到IP映射的整個過程。其中過程比較複雜,會存在信息的來回傳遞。畫圖的過程當中咱們會簡化信息來回傳遞的線段,重點放在信息傳遞的路徑,經過9步來詮釋DNS解析過程。
圖2 用戶請求以及DNS解析的全過程
A (Address) 記錄是用來指定主機名(或域名)對應的IP地址記錄。用戶能夠將該域名下的網站服務器指向到本身的web server上。同時也能夠設置您域名的二級域名。 CNAME:別名記錄。這種記錄容許您將多個名字映射到另一個域名。一般用於同時提供WWW和MAIL服務的計算機。例如,有一臺計算機名爲「host.mydomain.com」(A記錄)。它同時提供WWW和MAIL服務,爲了便於用戶訪問服務。服務商從方便維護的角度,通常也建議用戶使用CNAME記錄綁定域名的。若是主機使用了雙線IP,顯然使用CNAME也要方便一些。 TTL(Time To Live):也就是設置這個DNS解析在Local DNS Server上面的過時時間。超過了這個過時時間,URL和IP的映射就會被刪除,須要獲取還要請求Name Server。
GTM(Global Traffic Manager的簡寫)即全局流量管理,基於網宿智能DNS、分佈式監控體系,實現實時故障切換及全球負載均衡,保障應用服務的持續高可用性。傳給GTM的目的就是但願經過GTM的負載均衡機制,幫助用戶找到最適合本身的服務器IP。
也就是離本身最近,性能最好,服務器狀態最健康的。並且大多數的網站會作CDN緩存,此時就更須要使用GTM幫你找到網絡節點中適合你的CDN緩存服務器。
NS服務器是用來作URL與IP地址解析的,幫助用戶找到要訪問服務器的IP。從DNS服務器的結構來講大體分爲三層:根域名服務器,頂級域名服務器,本地域名服務器。
申請域名的供應商會提供Name Server做爲DNS解析。從用戶訪問一個網站出發,通過瀏覽器,本地Host文件、Local DNS Server、Root DNS Server、頂級域名服務器(gTLD、ccTLD、New gTLD)、Name Server、GTM、CDN、Application Server。共經歷了九個步驟。
做者:51CTO崔皓
來源:https://blog.51cto.com/142793...