摘要:也就是說,在域名解析的時(shí)候,不會(huì)將用戶導(dǎo)向真正的網(wǎng)站,而是指向這個(gè)緩存的服務(wù)器。什么是其實(shí)很簡單是基于協(xié)議和域名解析的流量調(diào)度解決方案。這就相當(dāng)于每家基于協(xié)議,自己實(shí)現(xiàn)自己的域名解析,做一個(gè)自己的地址簿,而不使用統(tǒng)一的地址簿。
【前五篇】系列文章傳送門:
網(wǎng)絡(luò)協(xié)議 12 - HTTP 協(xié)議:常用而不簡單
網(wǎng)絡(luò)協(xié)議 13 - HTTPS 協(xié)議:加密路上無盡頭
網(wǎng)絡(luò)協(xié)議 14 - 流媒體協(xié)議:要說愛你不容易
網(wǎng)絡(luò)協(xié)議 15 - P2P 協(xié)議:小種子大學(xué)問
網(wǎng)絡(luò)協(xié)議 16 - DNS 協(xié)議:網(wǎng)絡(luò)世界的地址簿
????全球統(tǒng)一的 DNS 是很權(quán)威,但是我們都知道“適合自己的,才是最好的”。很多時(shí)候,標(biāo)準(zhǔn)統(tǒng)一化的 DNS 并不能滿足我們定制的需求,這個(gè)時(shí)候就需要 HTTPDNS 了。
????上一節(jié)我們知道了 DNS 可以根據(jù)名稱查地址,也可以針對(duì)多個(gè)地址做負(fù)載均衡。然而,我們信任的地址簿也會(huì)存在指錯(cuò)路的情況。明明離你 500 米就有個(gè)吃飯的地方,非要把你推薦到 5 公里外。為什么會(huì)出現(xiàn)這樣的情況呢?
????還記得嗎?由我們發(fā)出請求解析 DNS 的時(shí)候,首先會(huì)連接到運(yùn)營商本地的 DNS 服務(wù)器,由這個(gè)服務(wù)器幫我們?nèi)フ?“DNS 樹” 上進(jìn)行解析,然后將解析的結(jié)果返回給客戶端。但是本地的 DNS 服務(wù)器,作為一個(gè)本地導(dǎo)游,往往會(huì)有自己的“小心思”。
傳統(tǒng) DNS 存在的問題1)域名緩存問題
????它可以在本地做一個(gè)緩存。也就是說,不是每一個(gè)請求,它都會(huì)去訪問權(quán)威 DNS 服務(wù)器,而是把訪問過一次的結(jié)果緩存到本地,當(dāng)其他人來問的時(shí)候,直接返回緩存的內(nèi)容。
????這就相當(dāng)于導(dǎo)游去過一個(gè)飯店,自己記住了地址,當(dāng)有一個(gè)游客問的時(shí)候,他就憑記憶回答了,不用再去查地址簿。這樣會(huì)存在一個(gè)問題,游客問的那個(gè)飯店如果已經(jīng)搬走了,然而因?yàn)閷?dǎo)游沒有刷新“記憶緩存”,導(dǎo)致游客白跑一趟。
????另外,有的運(yùn)營商會(huì)把一些靜態(tài)頁面,緩存到本運(yùn)營商的服務(wù)器內(nèi),這樣用戶請求的時(shí)候,就不用跨運(yùn)營商進(jìn)行訪問,既加快了速度,也減少了運(yùn)營商直接流量計(jì)算的成本。也就是說,在域名解析的時(shí)候,不會(huì)將用戶導(dǎo)向真正的網(wǎng)站,而是指向這個(gè)緩存的服務(wù)器。
????緩存的問題,很多情況下是看不出問題的,但是當(dāng)頁面更新,用戶訪問到老的頁面,問題就出來了。
????再就是本地的緩存,往往使得全局負(fù)載均衡失敗。上次進(jìn)行緩存的時(shí)候,緩存中的地址不一定是客戶此次訪問離客戶最近的地方,如果把這個(gè)地址返回給客戶,就會(huì)讓客戶繞遠(yuǎn)路了。
2)域名轉(zhuǎn)發(fā)問題
????還記得我們域名解析的過程嗎?捂臉是本地域名解析,還是去權(quán)威 DNS 服務(wù)器中查找,都可以認(rèn)為是一種外包形式。有了請求,直接轉(zhuǎn)發(fā)給其他服務(wù)去解析。如果轉(zhuǎn)發(fā)的是權(quán)威 DNS 服務(wù)器還好說,但是如果因?yàn)椤巴祽小鞭D(zhuǎn)發(fā)給了鄰居服務(wù)器去解析,就容易產(chǎn)生跨運(yùn)營商訪問的問題。
????這就好像,如果 A 運(yùn)營商的客戶,訪問自己運(yùn)營商的 DNS 服務(wù)器,A 運(yùn)營商去權(quán)威 DNS 服務(wù)器查詢的話,會(huì)查到客戶的 A 運(yùn)營商的,返回一個(gè)部署在 A 運(yùn)營商的網(wǎng)站地址,這樣針對(duì)相同運(yùn)營商的訪問,速度就會(huì)快很多。
????但是如果 A 運(yùn)營商偷懶,沒有轉(zhuǎn)發(fā)給權(quán)威 DNS ,而是轉(zhuǎn)發(fā)給了 B 運(yùn)營商,讓 B 運(yùn)營商再去權(quán)威 DNS 服務(wù)器查詢,這樣就會(huì)讓權(quán)威服務(wù)器誤認(rèn)為客戶是 B 運(yùn)營商的,返回一個(gè) B 運(yùn)營商的服務(wù)器地址,導(dǎo)致客戶每次都要跨運(yùn)營商訪問,訪問速度就會(huì)慢下來。
3)出口 NAT 問題
????前面了解網(wǎng)關(guān)的時(shí)候,我們知道,出口的時(shí)候,很多機(jī)房都會(huì)配置 NAT,也就是網(wǎng)絡(luò)地址轉(zhuǎn)換,使得從這個(gè)網(wǎng)關(guān)出去的包,都換成新的 IP 地址。
????這種情況下,權(quán)威 DNS 服務(wù)器就沒辦法通過請求 IP 來判斷客戶到底是哪個(gè)運(yùn)營商的,很有可能誤判運(yùn)營商,導(dǎo)致跨運(yùn)營商訪問。
4)域名更新問題
????本地 DNS 服務(wù)器是由不同地區(qū)、不同運(yùn)營商獨(dú)立部署的。對(duì)域名解析緩存的處理上,實(shí)現(xiàn)策略也有區(qū)別。有的會(huì)偷懶,忽略域名解析結(jié)構(gòu)的 TTL 時(shí)間限制,在權(quán)威 DNS 服務(wù)器解析變更的時(shí)候,解析結(jié)果在全網(wǎng)生效的周期非常漫長。但是有的場景,在 DNS 的切換中,對(duì)生效時(shí)間要求比較高。
????例如雙機(jī)房部署的是,跨機(jī)房的負(fù)載均衡和容災(zāi)多使用 DNS 來做。當(dāng)一個(gè)機(jī)房出問題之后,需要修改權(quán)威 DNS,將域名指向新的 IP 地址。但是如果更新太慢,很多用戶都會(huì)訪問一次。
5)解析延遲問題
????從 DNS 的查詢過程來看,DNS 的查詢過程需要遞歸遍歷多個(gè) DNS 服務(wù)器,才能獲得最終的解析結(jié)果,這帶來一定的延時(shí),甚至?xí)馕龀瑫r(shí)。
????上面總結(jié)了 DNS 的五個(gè)問題。問題有了,總得有解決辦法,就像因?yàn)?HTTP 的安全問題,才火了 HTTPS 協(xié)議一樣,對(duì)應(yīng)的,也有 HTTPDNS 來解決上述 DNS 出現(xiàn)的問題。
HTTPDNS什么是 HTTPDNS ?其實(shí)很簡單:
HTTPDNS 是基于 HTTP 協(xié)議和域名解析的流量調(diào)度解決方案。它不走傳統(tǒng)的 DNS 解析,而是自己搭建基于 HTTP 協(xié)議的 DNS 服務(wù)器集群,分布在多個(gè)地點(diǎn)和多個(gè)運(yùn)營商。當(dāng)客戶端需要 DNS 解析的時(shí)候,直接通過 HTTP 請求這個(gè)服務(wù)器集群,得到就近的地址。
????這就相當(dāng)于每家基于 HTTP 協(xié)議,自己實(shí)現(xiàn)自己的域名解析,做一個(gè)自己的地址簿,而不使用統(tǒng)一的地址簿。但是我們知道,域名解析默認(rèn)都是走 DNS 的,因而使用 HTTPDNS 需要繞過默認(rèn)的 DNS 路徑,也就不能使用默認(rèn)的客戶端。**使用 HTTPDNS 的,往往是手機(jī)應(yīng)用,需要在手機(jī)端嵌入支持 HTTPDNS 的客戶端 SDK。
HTTPDNS 的工作流程????接下來,我們一起來認(rèn)識(shí)下 HTTPDNS 的工作流程。
????HTTPDNS 會(huì)在客戶端的 SDK 里動(dòng)態(tài)請求服務(wù)端,獲取 HTTPDNS 服務(wù)器的 IP 列表,緩存在本地。隨著不斷地解析域名,SDK 也會(huì)在本地緩存 DNS 域名解析的結(jié)果。
????當(dāng)手機(jī)應(yīng)用要訪問一個(gè)地址的時(shí)候,首先看是否有本地的緩存,如果有直接返回。這個(gè)緩存和本地 DNS 的緩存不一樣的是,這個(gè)是手機(jī)應(yīng)用自己做的,而非整個(gè)運(yùn)營商統(tǒng)一做。如何更新以及何時(shí)更新緩存,手機(jī)應(yīng)用的客戶端可以和服務(wù)器協(xié)調(diào)來做這件事情。
????如果本地沒有,就需要請求 HTTPDNS 的服務(wù)器,在本地 HTTPDNS 服務(wù)器的 IP 列表中,選擇一個(gè)發(fā)出 HTTP 請求,獲取一個(gè)要訪問的網(wǎng)站的 IP 列表。
請求的方式是這樣的:
curl http://123.4.5.6/d?dn=c.m.cnb...
????手機(jī)客戶端之道手機(jī)在哪個(gè)運(yùn)營商、哪個(gè)地址。由于是直接的 HTTP 通信,HTTPDNS 服務(wù)器能夠準(zhǔn)確知道這些信息,因而可以做精準(zhǔn)的全局負(fù)載均衡。
????上面五個(gè)問題,歸結(jié)起來就兩大問題。一是解析速度和更新速度的平衡問題,二是智能調(diào)度的問題。HTTPDNS 對(duì)應(yīng)的解決方案是 HTTPDNS 的緩存設(shè)計(jì)和調(diào)度設(shè)計(jì)。
HTTPDNS 的緩存設(shè)計(jì)????解析 DNS 過程復(fù)雜,通信此時(shí)多,對(duì)解析速度造成很大影響。為了加快解析,因而有了緩存,但是這又會(huì)產(chǎn)生緩存更新速度不及時(shí)的問題。最要命的是,這兩個(gè)方面都掌握在別人手中,也就是本地 DNS 服務(wù)器手中,它不會(huì)為你定制,作為客戶端干著急也沒辦法。
????而 HTTPDNS 就是將解析速度和更新速度全部掌控在自己手中。
????一方面,解析的過程,不需要本地 DNS 服務(wù)遞歸的調(diào)用一大圈,一個(gè) HTTP 的請求直接搞定。要實(shí)時(shí)更新的時(shí)候,馬上就能起作用。
另一方面,為了提高解析速度,本地也有緩存,緩存是在客戶端 SDK 維護(hù)的,過期時(shí)間、更新時(shí)間,都可以自己控制。
HTTPDNS 的緩存設(shè)計(jì)策略也是咱們做應(yīng)用架構(gòu)中常用的緩存設(shè)計(jì)模式,也即分為客戶端、緩存、數(shù)據(jù)源三層。
對(duì)于應(yīng)用架構(gòu)來講,就是應(yīng)用、緩存、數(shù)據(jù)庫。常見的是 Tomcat、Redis、Mysql;
對(duì)于 HTTPDNS 來講,就是手機(jī)客戶端、DNS 緩存、HTTPDNS 服務(wù)器。
只要是緩存模式,就存在緩存的過期、更新、不一致的問題,解決思路也是相似的。
例如,DNS 緩存在內(nèi)存中,也可以持久化到存儲(chǔ)上,從而 APP 重啟之后,能夠盡快從存儲(chǔ)中加載上次累積的經(jīng)常訪問的網(wǎng)站的解析結(jié)果,就不需要每次都全部解析一遍,再變成緩存。這有點(diǎn)像 Redis 是基于內(nèi)存的緩存,但是同樣提供持久化的能力,使得重啟或者主備切換的時(shí)候,數(shù)據(jù)不會(huì)完全丟失。
SDK 中的緩存會(huì)嚴(yán)格按照緩存過期時(shí)間,如果緩存沒有命中,或者已經(jīng)過期,而且客戶端不允許使用過期的幾率,則會(huì)發(fā)起一次解析,保證緩存記錄是更新的。
解析可以同步進(jìn)行,也就是直接調(diào)用 HTTPDNS 的接口,返回最新的記錄,更新緩存。也可以異步進(jìn)行,添加一個(gè)解析任務(wù)到后臺(tái),由后臺(tái)任務(wù)調(diào)用 HTTPDNS 的接口。
同步更新的優(yōu)點(diǎn)是實(shí)時(shí)性好,缺點(diǎn)是如果有多個(gè)請求都發(fā)現(xiàn)過期的時(shí)候,會(huì)同時(shí)請求 HTTPDNS 多次,造成資源浪費(fèi)。
同步更新的方式對(duì)應(yīng)到應(yīng)用架構(gòu)緩存的 Cache-Aside 機(jī)制,也就是先讀緩存,不命中讀數(shù)據(jù)庫,同時(shí)將結(jié)果寫入緩存。
異步更新的優(yōu)點(diǎn)是,可以將多個(gè)請求都發(fā)現(xiàn)過期的情況,合并為一個(gè)對(duì)于 HTTPDNS 的請求任務(wù),只執(zhí)行一次,減少 HTTPDNS 的壓力。同時(shí),可以在即將過期的時(shí)候,就創(chuàng)建一個(gè)任務(wù)進(jìn)行預(yù)加載,防止過期之后再刷新,稱為預(yù)加載。
它的缺點(diǎn)是,當(dāng)前請求拿到過期數(shù)據(jù)的時(shí)候,如果客戶端允許使用過期時(shí)間,需要冒一次風(fēng)險(xiǎn)。這次風(fēng)險(xiǎn)是指,如果過期的請求還能請求,就沒問題,如果不能請求,就會(huì)失敗一次,等下次緩存更新后,才能請求成功。
異步更新的機(jī)制,對(duì)應(yīng)到應(yīng)用架構(gòu)緩存的 Refresh-Ahead 機(jī)制,即業(yè)務(wù)僅僅訪問緩存,當(dāng)過期的時(shí)候定期刷新。在著名的應(yīng)用緩存 Guava Cache 中,有個(gè) RefreshAfterWrite 機(jī)制,對(duì)于并發(fā)情況下,多個(gè)緩存訪問不命中從而引發(fā)并發(fā)回源的請求,可以采取只有一個(gè)請求回源的模式。在應(yīng)用架構(gòu)的緩存中,也常常用數(shù)據(jù)預(yù)熱或者預(yù)加載的機(jī)制。
HTTPDNS 的調(diào)度設(shè)計(jì)由于客戶端嵌入了 SDK,因而就不會(huì)因?yàn)楸镜?DNS 的各種緩存、轉(zhuǎn)發(fā)、NAT,讓權(quán)威 DNS 服務(wù)器誤會(huì)客戶端所在的位置和運(yùn)營商,從而可以拿到第一手資料。
在客戶端,可以知道手機(jī)是哪個(gè)國家、哪個(gè)運(yùn)營商、哪個(gè)省、甚至是哪個(gè)市,HTTPDNS 服務(wù)端可以根據(jù)這些信息,選擇最佳的服務(wù)節(jié)點(diǎn)返回。
如果有多個(gè)節(jié)點(diǎn),還會(huì)考慮錯(cuò)誤率、請求時(shí)間、服務(wù)器壓力、網(wǎng)絡(luò)狀態(tài)等,進(jìn)行綜合選擇,而非僅僅考慮地理位置。當(dāng)有一個(gè)節(jié)點(diǎn)宕機(jī)或者性能下降的時(shí)候,可以盡快進(jìn)行切換。
要做到這一點(diǎn),需要客戶端使用 HTTPDNS 返回的 IP 訪問業(yè)務(wù)應(yīng)用。客戶端的 SDK 會(huì)收集網(wǎng)絡(luò)請求數(shù)據(jù),如錯(cuò)誤率、請求時(shí)間等網(wǎng)絡(luò)請求質(zhì)量數(shù)據(jù),并發(fā)送到統(tǒng)計(jì)后臺(tái),進(jìn)行分析、聚合,以此查看不同 IP 的服務(wù)質(zhì)量。
在服務(wù)端,應(yīng)用可以通過調(diào)用 HTTPDNS 的管理接口,配置不同服務(wù)質(zhì)量的優(yōu)先級(jí)、權(quán)重。HTTPDNS 會(huì)根據(jù)這些策略綜合地理位置和線路狀況算出一個(gè)排序,優(yōu)先訪問當(dāng)前那些優(yōu)質(zhì)的、時(shí)延低的 IP 地址。
HTTPDNS 通過智能調(diào)度之后返回的結(jié)果,也會(huì)緩存在客戶端。為了不讓緩存使得調(diào)度失真,客戶端可以根據(jù)不同的移動(dòng)網(wǎng)絡(luò)運(yùn)營商的 SSID 來分維度緩存。不同的運(yùn)營商解析出來的結(jié)果會(huì)不同。
小結(jié)傳統(tǒng) DNS 會(huì)因?yàn)?strong>緩存、轉(zhuǎn)發(fā)、NAT 等問題導(dǎo)致客戶端誤會(huì)自己所在的位置和運(yùn)營商,從而影響流量的調(diào)度;
HTTPDNS 通過客戶端 SDK 和服務(wù)端,通過 HTTP 直接調(diào)用解析 DNS 的方式,繞過了傳統(tǒng) DNS 的缺點(diǎn),實(shí)現(xiàn)了智能的調(diào)度。
參考:
HTTPDNS 的原理;
劉超 - 趣談網(wǎng)絡(luò)協(xié)議系列課;
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/62058.html
摘要:也就是說,在域名解析的時(shí)候,不會(huì)將用戶導(dǎo)向真正的網(wǎng)站,而是指向這個(gè)緩存的服務(wù)器。什么是其實(shí)很簡單是基于協(xié)議和域名解析的流量調(diào)度解決方案。這就相當(dāng)于每家基于協(xié)議,自己實(shí)現(xiàn)自己的域名解析,做一個(gè)自己的地址簿,而不使用統(tǒng)一的地址簿。 【前五篇】系列文章傳送門: 網(wǎng)絡(luò)協(xié)議 12 - HTTP 協(xié)議:常用而不簡單 網(wǎng)絡(luò)協(xié)議 13 - HTTPS 協(xié)議:加密路上無盡頭 網(wǎng)絡(luò)協(xié)議 14 - 流媒體...
摘要:傳輸協(xié)議問題我們先解決第一個(gè),傳輸協(xié)議的問題。信封里面的信分抬頭和正文板栗燜雞協(xié)議我們學(xué)過,這個(gè)請求使用方法,發(fā)送一個(gè)格式為的正文給,從而下一個(gè)單,這個(gè)訂單封裝在的信封里面,并且表明這是一筆交易,而且訂單的詳情都已經(jīng)寫明了。 【前五篇】系列文章傳送門: 網(wǎng)絡(luò)協(xié)議 15 - P2P 協(xié)議:小種子大學(xué)問 網(wǎng)絡(luò)協(xié)議 16 - DNS 協(xié)議:網(wǎng)絡(luò)世界的地址簿 網(wǎng)絡(luò)協(xié)議 17 - HTTPDN...
摘要:傳輸協(xié)議問題我們先解決第一個(gè),傳輸協(xié)議的問題。信封里面的信分抬頭和正文板栗燜雞協(xié)議我們學(xué)過,這個(gè)請求使用方法,發(fā)送一個(gè)格式為的正文給,從而下一個(gè)單,這個(gè)訂單封裝在的信封里面,并且表明這是一筆交易,而且訂單的詳情都已經(jīng)寫明了。 【前五篇】系列文章傳送門: 網(wǎng)絡(luò)協(xié)議 15 - P2P 協(xié)議:小種子大學(xué)問 網(wǎng)絡(luò)協(xié)議 16 - DNS 協(xié)議:網(wǎng)絡(luò)世界的地址簿 網(wǎng)絡(luò)協(xié)議 17 - HTTPDN...
閱讀 3334·2021-11-22 12:04
閱讀 2718·2019-08-29 13:49
閱讀 491·2019-08-26 13:45
閱讀 2249·2019-08-26 11:56
閱讀 1007·2019-08-26 11:43
閱讀 601·2019-08-26 10:45
閱讀 1275·2019-08-23 16:48
閱讀 2164·2019-08-23 16:07