轉自:http://blog.csdn.net/cywosp/article/details/38017027算法
DNS(Domain Name System)是因特網的一項服務,它做爲域名和IP地址相互映射的一個分佈式數據庫,可以令人更方便的訪問互聯網。人們在經過瀏覽器訪問網站時只須要記住網站的域名便可,而不須要記住那些不太容易理解的IP地址。在DNS系統中有一個比較重要的的資源類型叫作主機記錄也稱爲A記錄,A記錄是用於名稱解析的重要記錄,它將特定的主機名映射到對應主機的IP地址上。若是你有一個本身的域名,那麼要想別人能訪問到你的網站,你須要到特定的DNS解析服務商的服務器上填寫A記錄,過一段時間後,別人就能經過你的域名訪問你的網站了。DNS除了能解析域名以外還具備負載均衡的功能,下面是利用DNS工做原理處理負載均衡的工做原理圖:
由上圖能夠看出,在DNS服務器中應該配置了多個A記錄,如:
www.apusapp.com IN A 114.100.20.201;
www.apusapp.com IN A 114.100.20.202;
www.apusapp.com IN A 114.100.20.203;
所以,每次域名解析請求都會根據對應的負載均衡算法計算出一個不一樣的IP地址並返回,這樣A記錄中配置多個服務器就能夠構成一個集羣,並能夠實現負載均衡。上圖中,用戶請求www.apusapp.com,DNS根據A記錄和負載均衡算法計算獲得一個IP地址114.100.20.203,並返回給瀏覽器,瀏覽器根據該IP地址,訪問真實的物理服務器114.100.20.203。全部這些操做對用戶來講都是透明的,用戶可能只知道www.apusapp.com這個域名。
DNS域名解析負載均衡有以下優勢:
1. 將負載均衡的工做交給DNS,省去了網站管理維護負載均衡服務器的麻煩。
2. 技術實現比較靈活、方便,簡單易行,成本低,使用於大多數TCP/IP應用。
3. 對於部署在服務器上的應用來講不須要進行任何的代碼修改便可實現不一樣機器上的應用訪問。
3. 服務器能夠位於互聯網的任意位置。
4. 同時許多DNS還支持基於地理位置的域名解析,即會將域名解析成距離用戶地理最近的一個服務器地址,這樣就能夠加速用戶訪問,改善性能。
同時,DNS域名解析也存在以下缺點:
1. 目前的DNS是多級解析的,每一級DNS均可能緩存A記錄,當某臺服務器下線以後,即便修改了A記錄,要使其生效也須要較長的時間,這段時間,DNS任然會將域名解析到已下線的服務器上,最終致使用戶訪問失敗。
2. 不可以按服務器的處理能力來分配負載。DNS負載均衡採用的是簡單的輪詢算法,不能區分服務器之間的差別,不能反映服務器當前運行狀態,因此其的負載均衡效果並非太好。
3. 可能會形成額外的網絡問題。爲了使本DNS服務器和其餘DNS服務器及時交互,保證DNS數據及時更新,使地址能隨機分配,通常都要將DNS的刷新時間設置的較小,但過小將會使DNS流量大增形成額外的網絡問題。
事實上,大型網站老是部分使用DNS域名解析,利用域名解析做爲第一級負載均衡手段,即域名解析獲得的一組服務器並非實際提供服務的物理服務器,而是一樣提供負載均衡服務器的內部服務器,這組內部負載均衡服務器再進行負載均衡,請請求發到真實的服務器上,最終完成請求。
參考:
[1] http://zh.wikipedia.org/zh/%E5%9F%9F%E5%90%8D%E7%B3%BB%E7%BB%9F
[2] http://blog.csdn.net/flynetcn/article/details/3733574
[3] 《大型網站技術架構——核心原理與案例分析》