糊塗窗口綜合症

糊塗窗口綜合症Silly window syndrome),亦稱愚蠢窗口綜合症愚笨窗口綜合症,是TCP流量控制英語Flow control (data)實現不良導致的一種計算機網絡問題。當發送程序緩慢地生產數據,接收程序緩慢地消耗數據,或者兩者同時存在時,滑動窗口運作會出現嚴重問題。如果一個服務器無法處理所有傳入的數據而存在此問題,它會要求客戶端減少一次發送的數據量(TCP網路封包的滑動窗口)。如果服務器仍然無法處理所有傳入的數據,窗口會隨此問題越來越小,有時甚至將使傳輸數據小於數據包頭,使數據傳輸變得極為低效。這個問題的名字取自窗口縮小到「愚蠢」的值。當該綜合症發生時,連接上交換的數據段是小數據段而不是全尺寸的數據段[1]

基於窗口的流量控制網絡協議,特別是使用非固定段大小的(例如TCP),都有可能陷入糊塗窗口綜合症[2]

處理每個封包都存在一定量的開銷英語Computational overhead,封包數增加會增加網絡通信的開銷,可能使數據處理量進一步減少。最終的結果就是抖動英語Thrashing (computer science)

描述 編輯

SWS 可能由 TCP 連接的任何一方引起:接收方應該等到可以發較大窗口通告再發窗口通告,但是沒有等而發了小窗口公告;發送方應該等到數據夠多的時候一次性發送一個較大的段,但是沒有等而發了較小的段[2]

解決方案 編輯

當發送者與接收者之間沒有就數據流量或數據包大小的容量同步時,則會發生窗口綜合症問題。如果糊塗窗口綜合症是由發送方產生,則納格算法發揮作用。 納格的解決方案要求發送方發送第一個英語TCP segment,即使它是小的,然後就等待直至收到一個ACK,或者累積到最大大小段(MSS)。如果糊塗窗口綜合症由接收方產生,則David D Clark算法英語David D Clark's algorithm發揮作用。Clark的解決方案是關閉窗口,直到接收到最大段大小(MSS)的另一個段,或者緩衝區為半空。

糊塗窗口綜合症的成因有三種:

  1. 當服務器宣布空閒空間為0
  2. 當客戶端每次只能生成1個字節
  3. 當服務器一次只能消耗1個字節

在糊塗窗口綜合症期間,通信效率幾乎為零,因此該問題的持續時間應儘可能短。

TCP 的實現要滿足以下規則[2]

  1. 接收方 TCP 不能通告小窗口。RFC 1122中定義的接收算法是不通告比當前正被通告的窗口大的段(可以是0),直到窗口可以增加一個全尺寸段(即接收MSS)或者增加接收方緩衝區的一半大,以較小者為準。在兩種情況下,該規則可以發揮作用: 當緩衝區中的部分數據已被應用程序消費而緩衝區可用時,以及當TCP必須響應窗口探測時。
  2. 發送方 TCP 不能發送過小的段,納格算法發揮作用。發送方只有以下情況才能發送段
    1. 待發送的數據為一個全尺寸的段。
    2. TCP 可以發送大小至少為另一端在此連接上通告的最大窗口大小的一半。
    3. 納格算法啟動的情況下,TCP 在沒有急需 ACK 的數據的情況下,TCP 可以發送任何它必須立即發送的數據。

其中 2.1 是最直截了當的,直接避免了段的開銷過高的問題。2.2 避免主機總是通告過小的窗口。2.3 避免 TCP 在有急需 ACK 的數據的情況下還發送比較小的段。如果發送方應用程序一直在往連接寫入大小很小的數據,2.3 可以避免糊塗窗口。2.2 要求發送方記錄接收方通告的最大窗口。

納格算法禁止我們在有急需ACK數據的情況下發送過小的段,那麼納格算法中的小指的是多小呢?2.1 說明大小不能小於SMSS(接收方的MSS或者不超過PMTU的最大包大小)[2]

發送端糊塗窗口避免 編輯

一種發送TCP的啟發法方法是必須允許發送程序執行「寫」調用,並在發送大段之前收集每個調用傳送的數據。發送TCP將延遲發送段,直到它累積起合理數量的數據。這被稱為聚集(clumping)。

接收端糊塗窗口避免 編輯

一種接收端的啟發式方法是維護可用窗口的內部記錄,並且延遲向發送方宣告增加窗口大小,直到可以推進顯着的量。該數量取決於接收端的緩衝器大小和最大段大小。通過此方法可以防止接收端程序緩慢提取八位元組數據時宣告小窗口。

參考資料 編輯

  • Comer, Douglas E. Internetworking with TCP/IP 5. Prentice Hall: Upper Saddle River, NJ. 2006. 
  • Postel, J. NCP/TCP Transition Plan. 1981 [5 October 2016]. (原始內容存檔於2016-06-10). Some TCP implementations did not protect against silly window syndrome. 
  1. ^ Clark, D. D. Window and Acknowledgement Strategy in TCP. tools.ietf.org. [2020-02-27]. (原始內容存檔於2019-03-27) (英語). 
  2. ^ 2.0 2.1 2.2 2.3 Fall; Kevin R. TCP/IP illustrated.—2nd ed. the United States of America: Pearson Education, Inc. 2012: 708. ISBN 0-321-33631-3. 

外部連結 編輯