DNS使用的是TCP協議還是UDP協議

2021-08-09 10:50:40 字數 1561 閱讀 6948

原文:

dns同時占用udp和tcp埠53是公認的,這種單個應用協議同時使用兩種傳輸協議的情況在tcp/ip棧也算是個另類。但很少有人知道dns分別在什麼情況下使用這兩種協議。

先簡單介紹下tcp與udp。

tcp是一種面向連線的協議,提供可靠的資料傳輸,一般服務質量要求比較高的情況,使用這個協議。udp—使用者資料報協議,是一種無連線的傳輸層協議,提供面向事務的簡單不可靠資訊傳送服務。

tcp與udp的區別:

udp和tcp協議的主要區別是兩者在如何實現資訊的可靠傳遞方面不同。tcp協議中包含了專門的傳遞保證機制,當資料接收方收到傳送方傳來的資訊時,會自動向傳送方發出確認訊息;傳送方只有在接收到該確認訊息之後才繼續傳送其它資訊,否則將一直等待直到收到確認資訊為止。 與tcp不同,udp協議並不提供資料傳送的保證機制。如果在從傳送方到接收方的傳遞過程中出現資料報的丟失,協議本身並不能做出任何檢測或提示。因此,通常人們把udp協議稱為不可靠的傳輸協議。相對於tcp協議,udp協議的另外乙個不同之處在於如何接收突發性的多個資料報。不同於tcp,udp並不能確保資料的傳送和接收順序。事實上,udp協議的這種亂序性基本上很少出現,通常只會在網路非常擁擠的情況下才有可能發生。

既然udp是一種不可靠的網路協議,那麼還有什麼使用價值或必要呢?其實不然,在有些情況下udp協議可能會變得非常有用。因為udp具有tcp所望塵莫及的速度優勢。雖然tcp協議中植入了各種安全保障功能,但是在實際執行的過程中會占用大量的系統開銷,無疑使速度受到嚴重的影響。反觀udp由於排除了資訊可靠傳遞機制,將安全和排序等功能移交給上層應用來完成,極大降低了執行時間,使速度得到了保證。

dns在進行區域傳輸的時候使用tcp協議,其它時候則使用udp協議;

dns的規範規定了2種型別的dns伺服器,乙個叫主dns伺服器,乙個叫輔助dns伺服器。在乙個區中主dns伺服器從自己本機的資料檔案中讀取該區的dns資料資訊,而輔助dns伺服器則從區的主dns伺服器中讀取該區的dns資料資訊。當乙個輔助dns伺服器啟動時,它需要與主dns伺服器通訊,並載入資料資訊,這就叫做區傳送(zone transfer)。

為什麼既使用tcp又使用udp?

首先了解一下tcp與udp傳送位元組的長度限制:

udp報文的最大長度為512位元組,而tcp則允許報文長度超過512位元組。當dns查詢超過512位元組時,協議的tc標誌出現刪除標誌,這時則使用tcp傳送。通常傳統的udp報文一般不會大於512位元組。

區域傳送時使用tcp,主要有一下兩點考慮:

1.輔網域名稱伺服器會定時(一般時3小時)向主網域名稱伺服器進行查詢以便了解資料是否有變動。如有變動,則會執行一次區域傳送,進行資料同步。區域傳送將使用tcp而不是udp,因為資料同步傳送的資料量比乙個請求和應答的資料量要多得多。

2.tcp是一種可靠的連線,保證了資料的準確性。

網域名稱解析時使用udp協議:

客戶端向dns伺服器查詢網域名稱,一般返回的內容都不超過512位元組,用udp傳輸即可。不用經過tcp三次握手,這樣dns伺服器負載更低,響應更快。雖然從理論上說,客戶端也可以指定向dns伺服器查詢的時候使用tcp,但事實上,很多dns伺服器進行配置的時候,僅支援udp查詢包。

滴滴面試2DNS使用的是TCP協議還是UDP協議

dns同時占用udp和tcp埠53是公認的,這種單個應用協議同時使用兩種傳輸協議的情況在tcp ip棧也算是個另類。但很少有人知道dns分別在什麼情況下使用這兩種協議。先簡單介紹下tcp與udp。tcp是一種面向連線的協議,提供可靠的資料傳輸,一般服務質量要求比較高的情況,使用這個協議。udp 使用...

DNS使用的是TCP協議還是UDP協議簡析

dns使用的是tcp協議還是udp協議簡析 dns同時占用udp和tcp埠53是公認的,這種單個應用協議同時使用兩種傳輸協議的情況在tcp ip棧也算是個另類。但很少有人知道dns分別在什麼情況下使用這兩種協議。先簡單介紹下tcp與udp。tcp是一種面向連線的協議,提供可靠的資料傳輸,一般服務質量...

DNS用的是TCP協議還是UDP協議

1 瀏覽器快取 當使用者通過瀏覽器訪問某網域名稱時,瀏覽器首先會在自己的快取中查詢是否有該網域名稱對應的ip位址 若曾經訪問過該網域名稱且沒有清空快取便存在 2 系統快取 當瀏覽器快取中無網域名稱對應ip則會自動檢查使用者計算機系統hosts檔案dns快取是否有該網域名稱對應ip 3 路由器快取 當...