【實驗問題記錄】DNS EDNS0 IP分片

為了測量一個 DNS 服務器的放大性能,使用dig命令向能夠放大的 DNS 服務器請求某個具有大量回復的域名的 ANY 資源,并利用 tcpdump 進行捕包。
dig @x.x.x.x xxx.gov ANY
tcpdump -i interface -n -vv '(udp) and (port 53) and (host x.x.x.x)'

問題1:

  • 問題描述:收到了一個 IP 包長度為1500的分片包,但沒有收到后續的 IP 分片包。
  • 解釋:這是因為除了第一個分片包,其他分片包本身并不包含 UDP 或 TCP 頭部,所以也無從得知這些 IP 包的端口號,后續的IP分片包也就被過濾掉了。
  • 解決辦法:把port 53這一過濾條件刪除。

問題2:

  • 問題描述:根據RFC 1035,使用UDP的 DNS 回復包大小被限制在512字節,但是這次回復顯然超過了512字節,這是為什么?
  • 解釋:x.x.x.x DNS 服務器應該實現了 DNS 擴展機制——EDNS0,EDNS0允許大于512字節的UDP回復包。DNS 響應因為引入了一些大型數據項,如 AAAA 記錄,DNSSEC 信息(例如RRSIG或DNSKEY),或大型 TXT 記錄,導致其大小增加。EDNS 提供更大的 UDP 載荷能力可以避免 DNS 廣泛使用 TCP 進行通信,提高 DNS 的可伸縮性。關于 EDNS 詳情參考RFC 6891

問題3

  • 問題描述:dig提示;; Truncated, retrying in TCP mode.,也就是說回復太大,被DNS服務器截斷了,并沒有返回完整的資源記錄,重新使用了TCP進行查詢。對比了一下 TCP 回復的資源記錄和 UDP 回復的資源記錄,TCP 回復的資源記錄更多,也就是說即使啟用了 EDNS0,仍然會有最大長度的限制,超過這個限制仍然會轉去使用 TCP。那這個限制是多少呢?是在客戶端設置的還是服務器端設置的呢?

  • 解釋:在RFC 6891的 Payload Size Selection 章節中討論了這一問題:

    Due to transaction overhead, it is not recommended to advertise an architectural limit as a maximum UDP payload size. Even on system stacks capable of reassembling 64 KB datagrams, memory usage at low levels in the system will be a concern. A good compromise may be the use of an EDNS maximum payload size of 4096 octets as a starting point. A good compromise may be the use of an EDNS maximum payload size of 4096 octets as a starting point.

    大致意思是考慮到傳輸的開銷,不建議把可接收的UDP負載設的太大,所以把'EDNS的最大有效載荷大小為4096字節'作為一個折衷方案。
    實驗表明,UDP負載大小限制是在服務器端設置的,和客戶端發送的請求包中 OPT 記錄設置沒有關系(請求包中有OPT 記錄表明客戶端支持 EDNS,如果沒有,DNS 服務器最多回復512字節,如下圖所示)。關于服務器是如何設置的以及為什么不需要看請求包的 OPT 記錄還需要查看RFC 6891進行確認。

    dig-DNS請求包

實驗過程如下:
dig @x.x.x.x xxx.gov ANY +bufsize=1024
dig @x.x.x.x xxx.gov ANY +bufsize=8192
"+bufsize=xxxx"是把請求包的 OPT 資源 UDP payload size 修改成xxxx,DNS 請求包證實可以修改,如下圖所示:

dig-bufsize8192-DNS請求包

但是從收到的回復包來看不管設置成1024還是8196,服務器仍然按照4096進行截斷。也就是說這個UDP負載大小限制是在服務器端設置的,和客戶端發送的請求包中 OPT 記錄設置沒有關系。


image.png

參考資料:

  1. 使用 DNS 的擴展名機制 (EDNS0),oschina.
  2. DNS系統與DDOS攻擊的關聯,51web.
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,156評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,401評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,069評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,873評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,635評論 6 408
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,128評論 1 323
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,203評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,365評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,881評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,733評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,935評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,475評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,172評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,582評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,821評論 1 282
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,595評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,908評論 2 372

推薦閱讀更多精彩內容

  • 個人認為,Goodboy1881先生的TCP /IP 協議詳解學習博客系列博客是一部非常精彩的學習筆記,這雖然只是...
    貳零壹柒_fc10閱讀 5,079評論 0 8
  • 簡介 用簡單的話來定義tcpdump,就是:dump the traffic on a network,根據使用者...
    保川閱讀 5,976評論 1 13
  • 在使用consul做docker容器服務化的過程中,使用到了dnsmasq做DNS請求轉發,于是研究了下DNS協議...
    __七把刀__閱讀 4,009評論 2 13
  • 簡介 用簡單的話來定義tcpdump,就是:dump the traffic on a network,根據使用者...
    JasonShi6306421閱讀 1,251評論 0 1
  • 1.TCP報頭格式 UDP報頭格式 TCP報頭格式 UDP報頭格式 具體的各部分解釋看 TCP報文格式詳解 - ...
    杰倫哎呦哎呦閱讀 2,486評論 0 5