TCP擁塞控制
TCP擁塞控制是傳輸控制協定(英語:Transmission Control Protocol,縮寫TCP)避免網路擁塞的演算法,是網際網路上主要的一個擁塞控制措施。它使用一套基於線增積減模式的多樣化網路擁塞控制方法(包括慢啟動和擁塞窗口等模式)來控制擁塞。[1][2][3][4][5]在網際網路上應用中有相當多的具體實現演算法。
運作方法
編輯TCP使用多種擁塞控制策略來避免雪崩式擁塞。TCP會為每條連接維護一個「擁塞窗口」來限制可能在端對端間傳輸的未確認分組總數量。這類似TCP流量控制機制中使用的滑動窗口。TCP在一個連接初始化或逾時後使用一種「慢啟動」機制來增加擁塞窗口的大小。[6]它的起始值一般為最大分段大小(Maximum segment size,MSS)的兩倍,雖然名為「慢啟動」,初始值也相當低,但其增長極快:當每個分段得到確認時,擁塞窗口會增加一個MSS,使得在每次往返時間(round-trip time,RTT)內擁塞窗口能高效地雙倍增長。
當擁塞窗口超過慢啟動閾值(ssthresh)時,演算法就會進入一個名為「擁塞避免」的階段。[註 1]在擁塞避免階段,只要未收到重複確認,擁塞窗口則在每次往返時間內線性增加一個MSS大小。[註 2]
擁塞窗口
編輯在TCP中,擁塞窗口(congestion window)是任何時刻內確定能被傳送出去的位元組數的控制因素之一,是阻止傳送方至接收方之間的鏈路變得擁塞的手段。他是由傳送方維護,通過估計鏈路的擁塞程度計算出來的,與由接收方維護的接收窗口大小並不衝突。
當一條連接建立後,每個主機獨立維護一個擁塞窗口並設定值為連接所能承受的MSS的最小倍數,之後的變化依靠線增積減機制來控制,這意味如果所有分段到達接收方和確認包準時地回到傳送方,擁塞窗口會增加一定數量。該窗口會保持指數增大,直到發生逾時或者超過一個稱為「慢啟動閾值(ssthresh)」的限值。如果傳送方到達這個閾值時,每收到一個新確認包,擁塞窗口只按照線性速度增加自身值的倒數。
當發生逾時的時候,慢啟動閾值降為逾時前擁塞窗口的一半大小、擁塞窗口會降為1個MSS,並且重新回到慢啟動階段。
系統管理員可以設定窗口最大限值,或者調整擁塞窗口的增加量,來對TCP調優。
在流量控制中,接收方通過TCP的「窗口」值(Window Size)來告知傳送方,由傳送方通過對擁塞窗口和接收窗口的大小比較,來確定任何時刻內需要傳輸的資料量。
慢啟動
編輯慢啟動(Slow-start)是用於結合其他階段演算法,來避免傳送過多資料到網路中而導致網路擁塞,演算法在RFC 5681中定義。
慢啟動初始啟動時設定擁塞窗口值(cwnd)為1、2、4或10個MSS。[7][8]:1擁塞窗口在每接收到一個確認包時增加,每個RTT內成倍增加,當然實際上並不完全是指數增長,因為接收方會延遲傳送確認,通常是每接收兩個分段則傳送一次確認包。[9]傳送速率隨著慢啟動的進行而增加,直到遇到出現遺失、達到慢啟動閾值(ssthresh)、或者接收方的接收窗口進行限制。如果發生遺失,則TCP推斷網路出現了擁塞,會試圖採取措施來降低網路負載。這些是靠具體使用的TCP擁塞演算法來進行測量判斷。當達到慢啟動閾值(ssthresh)時,慢啟動演算法就會轉換為線性增長的階段,演算法控制每個RTT內擁塞窗口只增加1個分段量。雖然稱為「慢啟動」,但實際上比擁塞控制階段的窗口增加更為激進。[10]
對於處理報文遺失這個事件上,不同擁塞控制演算法表現有所不同:
- TCP Tahoe
- 對於TCP Tahoe演算法,當發生遺失時,會進入「快速重傳」機制,慢啟動閾值設為之前擁塞窗口值的一半,擁塞窗口值降為初始值,重新進入慢啟動階段。當擁塞窗口值達到慢啟動閾值時,每RTT內擁塞窗口增加值則為「MSS除以CWND」的值,所以擁塞窗口按線性速度增加。
- TCP Reno
- TCP Reno演算法實現了一個名為「快速恢復」的機制,慢啟動閾值設為之前擁塞窗口值的一半,和作為新的擁塞窗口值,並跳過慢啟動階段,直接進入擁塞控制階段。
慢啟動假設分段的未確認是由於網路擁塞造成的,雖然大部分網路的確如此,但也有其他原因,例如一些鏈路品質差的網路,會導致分段包遺失。在一些網路環境,例如無線網路,慢啟動效率並不好。
慢啟動對於一些短暫的連接效能並不好,一些較舊的網頁瀏覽器會建立大量連續的短暫連結,通過快速開啟和關閉連結來請求獲得檔案,這使得大多數連結處於慢啟動模式,導致網頁回應時間差。所以現在新的網頁瀏覽器,會通過向特殊的伺服器,開啟一條連結來請求獲得全部的檔案,而避免頻繁新建大量短暫連結。不過這樣對一些非請求網站所提供的服務,例如廣告跟蹤指令碼、社交分享功能指令碼、網路分析指令碼等,並不適用。[11]
和式增加,積式減少
編輯和性增長/乘性降低(additive-increase/multiplicative-decrease,AIMD,這裡簡稱「線增積減」)是一種回饋控制演算法,其包含了對擁塞窗口線性增加,和當發生擁塞時對窗口積式減少。多個使用AIMD控制的TCP流最終會收斂到對線路的等量競爭使用。[12]
快速重傳
編輯快速重傳(Fast retransmit)是對TCP傳送方降低等待重發遺失分段用時的一種改進。TCP傳送方每傳送一個分段都會啟動一個逾時計時器,如果沒能在特定時間內接收到相應分段的確認,傳送方就假設這個分段在網路上遺失了,需要重發。這也是 TCP 用來估計 RTT 的測量方法。
重複確認(duplicate cumulative acknowledgements,DupAcks)就是這個階段的基礎,其基於以下過程:如果接收方接收到一個資料分段,就會將該分段的序列號加上資料位元組長的值,作為分段確認的確認號,傳送回傳送方,表示期望傳送方傳送下一個序列號的分段。但是如果接收方提前收到更下一個序列號的分段——或者說接收到無序到達的分段,即之前期望確認號對應的分段出現接收遺失——接收方需要立即使用之前的確認號傳送分段確認。此時如果傳送方收到接收方相同確認號的分段確認超過1次,並且該對應序列號的分段逾時計時器仍沒逾時的話,則這就是出現重複確認,需要進入快速重傳。
快速重傳就是基於以下機制:如果假設重複閾值為3,當傳送方收到4次相同確認號的分段確認(第1次收到確認期望序列號,加3次重複的期望序列號確認)時,則可以認為繼續傳送更高序列號的分段將會被接受方丟棄,而且會無法有序送達。傳送方應該忽略逾時計時器的等待重發,立即重發重複分段確認中確認號對應序列號的分段。
具體實現演算法
編輯「TCP+演算法名稱」這一TCP演算法命名方式最早出在凱文·福爾(Kevin Fall)和莎莉·弗洛伊德(Sally Floyd)在1996年發布的一篇論文中。[13]
TCP Tahoe 和 Reno
編輯這兩個演算法是根據其第一次加入到4.3BSD的時間回溯命名的,兩個名字對應自其第一次出現時BSD的代號,而代號分別取自太浩湖(Lake Tahoe)和其附近的城市雷諾市。「Tahoe」演算法實現在4.3BSD-Tahoe中第一次加入,之後在4.3BSD網路發布第一版實現了脫AT&T授權版本,使其能更容易被廣泛再發布與實現。改進版「Reno」在4.3BSD-Reno中實現,並之後通過「4.3BSD網路發布第二版」和4.4BSD-Lite發布。
兩者演算法大致一致,對於丟包事件判斷都是以重傳逾時(retransmission timeout,RTO)和重複確認為條件,但是對於重複確認的處理,兩者有所不同:
- Tahoe:如果收到三次重複確認——即第四次收到相同確認號的分段確認,並且分段對應包無負載分段和無改變接收窗口——的話,Tahoe演算法則進入快速重傳,將慢啟動閾值改為當前擁塞窗口的一半,將擁塞窗口降為1個MSS,並重新進入慢啟動階段。[15]
- Reno:如果收到三次重複確認,Reno演算法則進入快速重傳,只將擁塞窗口減半來跳過慢啟動階段,將慢啟動閾值設為當前新的擁塞窗口值,進入一個稱為「快速恢復」的新設計階段。
對於RTO,兩個演算法都是將擁塞窗口降為1個MSS,然後進入慢啟動階段。[15]
快速恢復
編輯快速恢復(Fast recovery)是Reno演算法新引入的一個階段,在將遺失的分段重傳後,啟動一個逾時定時器,並等待該遺失分段包的分段確認後,再進入擁塞控制階段。如果仍然逾時,則回到慢啟動階段。
TCP Vegas
編輯至1990年代中期,TCP量度延遲和RTT都是以傳輸快取中最後一個被傳送的分段包為準。亞利桑那大學的研究人員拉里·彼得森和勞倫斯·布拉科夫提出了新的TCP擁塞演算法「TCP Vegas」,[16][17]其實通過度量傳輸快取中每個傳送分段包來代替只量度一個分段包,根據每次度量的平均值來增加擁塞窗口。[18]該演算法取名自內華達州最大的城市拉斯維加斯。不過由於一些資源公平性原因,該演算法並沒有在彼得森的實驗室之外廣泛部署。一些研究認為該演算法和其他擁塞演算法混合使用,可能會導致效能競爭不及其他演算法。[19][20][21][22]在各種TCP擁塞演算法的比較研究中,Vegas被認為是最平滑的控制演算法,其次為CUBIC。[23]
DD-WRT在v24 SP2開始將該演算法作為其預設的TCP擁塞控制演算法。[24]
TCP New Reno
編輯TCP New Reno是對TCP Reno中快速恢復階段的重傳進行改善的一種改進演算法,其定義於RFC 6582,覆蓋了原有在RFC 3782和RFC 2582的舊定義。
在Reno的快速恢復中,一旦出現3次重複確認,TCP傳送方會重發重複確認對應序列號的分段並設定定時器等待該重發分段包的分段確認包,當該分段確認包收到後,就立即退出快速恢復階段,進入擁塞控制階段,但如果某個導致重複確認的分段包到遇到重複確認期間所傳送的分段包存在多個遺失的話,則這些遺失只能等待逾時重發,並且導致擁塞窗口多次進入擁塞控制階段而多次下降。而New Reno的快速恢復中,一旦出現3次重複確認,TCP傳送方先記下3次重複確認時已傳送但未確認的分段的最大序列號,然後重發重複確認對應序列號的分段包。如果只有該重複確認的分段遺失,則接收方接收該重發分段包後,會立即返回最大序列號的分段確認包,從而完成重發;但如果重複確認期間的傳送包有多個遺失,接收方在接收該重發分段後,會返回非最大序列號的分段確認包,從而傳送方繼續保持重發這些遺失的分段,直到最大序列號的分段確認包的返回,才退出快速恢復階段。[18]
New Reno在低錯誤率時執行效率和「選擇確認」(Selective ACKnowledgement,SACK)相當,在高錯誤率仍優於Reno。[25]
TCP Hybla
編輯TCP Hybla旨在消除由於高延遲地面線路或者衛星無線鏈路下導致的RTT過長而對TCP連結的影響。它通過對擁塞窗口動態分析來修改,來減少對RTT的效能依賴。[26]
TCP BIC 和 CUBIC
編輯TCP BIC(Binary Increase Congestion control)旨在最佳化高速高延遲網路(即根據RFC 1072所定義的「長肥網路」(long fat network,LFN)[27])的擁塞控制,其擁塞窗口演算法使用二分搜尋演算法嘗試找到能長時間保持擁塞窗口最大值的值。[28]Linux核心在2.6.8至2.6.18使用該演算法作為預設TCP擁塞演算法。[29]
CUBIC則是比BIC更溫和和系統化的分支版本,其使用三次函式代替二分演算法作為其擁塞窗口演算法,並且使用函式拐點作為擁塞窗口的設定值。[28]Linux核心在2.6.19後使用該演算法作為預設TCP擁塞演算法。[30]
TCP Westwood和Westwood+
編輯TCP Westwood改良自New Reno,不同於以往其他擁塞控制演算法使用遺失來測量,其通過對確認包測量來確定一個「合適的傳送速度」,並以此調整擁塞窗口和慢啟動閾值。其改良了慢啟動階段演算法為「敏捷探測(Agile Probing)」,和設計了一種持續探測擁塞窗口的方法來控制進入「敏捷探測」,使連結儘可能地使用更多的頻寬。Westwood+使用更長的頻寬估計間隔和最佳化的濾波器來修正Westwood對ACK壓縮場景對頻寬估計過高的問題。通過以上改良,TCP Westwood系列演算法在有線網路和無線網路的擁塞控制上取得平衡,尤其研究中針對於無線通訊網路上。[31][32]
Compound TCP
編輯複合TCP(Compound TCP)是微軟自己實現的TCP擁塞控制演算法,通過同時維護兩個擁塞窗口,來實現在長肥網路有較好的效能而又不損失公平性。該演算法在Windows Vista和Windows Server 2008開始廣泛部署,[33]並通過修補程式的方式回溯支援到Windows XP和Windows Server 2003。[34]在Linux上也有一個舊版本的移植實現。[35]
TCP PRR
編輯TCP PRR(TCP Proportional Rate Reduction )[36]是旨在恢復期間提高傳送資料的準確性。該演算法確保恢復後的擁塞窗口大小儘可能接近慢啟動閾值。在Google進行的測試中,能將平均延遲降低3~10%,恢復的逾時減少5%。[37]PRR演算法之後作為Linux核心3.2版本的預設擁塞演算法。[38]
TCP BBR
編輯TCP BBR(Bottleneck Bandwidth and Round-trip propagation time)是由Google設計,於2016年發布的擁塞演算法。以往大部分擁塞演算法是基於丟包來作為降低傳輸速率的訊號,而BBR則基於模型主動探測。該演算法使用網路最近出站資料分組當時的最大頻寬和往返時間來建立網路的顯式模型。封包傳輸的每個累積或選擇性確認用於生成記錄在封包傳輸過程和確認返回期間的時間內所傳送資料量的取樣率。[39]該演算法認為隨著網路介面控制器逐漸進入千兆速度時,與緩衝膨脹相關的延遲相比丟包更應該被認為是辨識擁塞的主要決定因素,所以基於延遲模型的擁塞控制演算法(如BBR)會有更高的吞吐量和更低的延遲,可以用BBR來替代其他流行的擁塞演算法,例如CUBIC。Google在YouTube上應用該演算法,將全球平均的YouTube網路吞吐量提高了4%,在一些國家超過了14%。[40]
BBR之後移植入Linux核心4.9版本,[41][42]並且對於QUIC可用。
BBR效率很高,速度也很快,但是它與非BBR的流的公平性有爭議。雖然谷歌的展示顯示 BBR 與 CUBIC 共存良好,但像傑夫·休斯頓和霍克、布利斯和齊特巴特等研究者發現它對其他流不公平,並且不可延伸。[43]霍克等人還發現,在Linux 4.9的BBR實現中「存在一些嚴重的原生問題,如排隊延遲增加、不公平和大量封包遺失」。[44]
索海爾·阿巴斯洛等人(C2TCP的作者)指出,BBR在動態環境中表現不佳,比如蜂巢式網路。[45][46]他們還表明BBR存在不公平問題。例如,當一個CUBIC流(在Linux、Android和MacOS中是預設的TCP實現)與網路中的BBR流共存時,BBR流可以支配 CUBIC 流並從中獲得整個鏈路頻寬[45]。
註腳
編輯參考文獻
編輯- ^ Van Jacobson, Michael J. Karels. Congestion Avoidance and Control (頁面存檔備份,存於網際網路檔案館) (1988). Proceedings of the Sigcomm '88 Symposium, vol.18(4): pp.314–329. Stanford, CA. August 1988. This paper originated many of the congestion avoidance algorithms used in TCP/IP.
- ^ RFC 2001 – TCP Slow Start, Congestion Avoidance, Fast Retransmit, and Fast Recovery Algorithms
- ^ RFC 5681 – TCP Congestion Control
- ^ RFC 3390 – TCP Increasing TCP's Initial Window
- ^ TCP Congestion Avoidance Explained via a Sequence Diagram (PDF). [2018-04-19]. (原始內容 (PDF)存檔於2010-11-22).
- ^ Jacobson, Van; Karels, Michael. Congestion Avoidance and Control (PDF). ACM SIGCOMM Computer Communication Review. 1988, 25 (1): 157–187 [2018-04-19]. doi:10.1145/205447.205462. (原始內容存檔 (PDF)於2013-05-12).
- ^ Corbet, Jonathan. Increasing the TCP initial congestion window. LWN. [2012-10-10]. (原始內容存檔於2012-10-17).
- ^ Increasing TCP's Initial Window. RFC 3390.
- ^ TCP Slow Start, Congestion Avoidance, Fast Retransmit, and Fast Recovery Algorithms. January 1997 [2018-04-19]. (原始內容存檔於2016-03-10).
- ^ Jacobson, Van; Karels, MJ. Congestion avoidance and control (PDF). ACM SIGCOMM Computer Communication Review. 1988, 18 (4): 314–329 [2018-04-19]. doi:10.1145/52325.52356. (原始內容 (PDF)存檔於2004-06-22).
- ^ What's Making Your Site Go Slow? Could Be The Like Button. allfacebook.com. 2010-11-10 [2018-03-26]. (原始內容存檔於2014-08-18) (美國英語).
- ^ Chiu, Dah-Ming; Raj Jain. Analysis of increase and decrease algorithms for congestion avoidance in computer networks. Computer Networks and ISDN systems. 1989, 17: 1–14.
- ^ Fall, Kevin; Sally Floyd. Simulation-based Comparisons of Tahoe, Reno and SACK TCP (PostScript). Computer Communications Review. July 1996 [2018-04-19]. (原始內容存檔於2020-01-17).
- ^ Kurose, James; Ross, Keith. Computer Networking – A Top-Down Approach 4th. Addison Wesley. 2008. ISBN 978-0-13-607967-5.
- ^ 15.0 15.1 Kurose & Ross 2008[14], p. 284.
- ^ Understanding TCP Vegas: Theory and Practice* | Computer Science Department at Princeton University. www.cs.princeton.edu. [2018-02-21]. (原始內容存檔於2018-03-16) (英語).
- ^ Kim, Cheeha. Information Networking: Convergence in Broadband and Mobile Networking. International Conference, ICOIN 2005, Jeju Island, Korea, January 31 - February 2, 2005, Proceedings. Springer Science & Business Media. 2005-01-24 [2018-02-21]. (原始內容存檔於2018-04-19) (英語).
- ^ 18.0 18.1 A Comparative Analysis of TCP Tahoe, Reno, New-Reno, SACK and Vegas (PDF). [2018-04-19]. (原始內容存檔 (PDF)於2017-08-29).
- ^ Issues in TCP Vegas (PDF). [2018-04-19]. (原始內容存檔 (PDF)於2008-05-12).
- ^ Brakmo, Lawrence S. TCP Vegas: New techniques for congestion detection and avoidance. 1994 [2018-02-21]. (原始內容存檔於2016-03-04).
- ^ Srikant, Rayadurgam. The Mathematics of Internet Congestion Control. Springer Science & Business Media. 2004 [2018-02-21]. (原始內容存檔於2018-04-19) (英語).
- ^ Venkatesh, T. An Analytical Approach to Optical Burst Switched Networks. Springer Science & Business Media. 2010-03-16 [2018-02-21]. (原始內容存檔於2018-04-19) (英語).
- ^ Performance Analysis of TCP Congestion Control Algorithms (PDF). [2012-03-26]. (原始內容存檔 (PDF)於2014-03-10).
- ^ DD-WRT changelog. [2012-01-02]. (原始內容存檔於2012-01-24).
- ^ Das, Vinu; Thankachan, Nessy. Computational Intelligence and Information Technology: First International Conference, CIIT 2011, Pune, India, November 7-8, 2011. Proceedings. Computational Intelligence and Information Technology. Springer Science & Business Media. 2013-01-02 [2018-04-19]. ISBN 9783642257339. (原始內容存檔於2018-04-19) (英語).
- ^ Caini, Carlo; Firrincieli, Rosario. TCP Hybla: a TCP enhancement for heterogeneous networks. International Journal of Satellite Communications and Networking. 2004-09-01, 22 (5): 547–566 [2018-04-19]. ISSN 1542-0981. doi:10.1002/sat.799. (原始內容存檔於2018-01-16) (英語).
- ^ V., Jacobson,. TCP extensions for long-delay paths. tools.ietf.org. [2017-09-02]. (原始內容存檔於2017-07-07) (英語).
- ^ 28.0 28.1 BIC and CUBIC | Networking Research Lab. 2012-12-12 [2017-09-02]. (原始內容存檔於2010-10-06).
- ^ ChangeLog-2.6.8. kernel.org. [2017-09-02]. (原始內容存檔於2017-09-08).
- ^ Proceedings of the Linux Symposium (PDF). kernel.org. 2009-07-17 [2018-04-19]. (原始內容存檔 (PDF)於2013-07-31).
- ^ TCP Westwood网络拥塞协议分析与控制研究--《安徽大学》2015年硕士论文. cdmd.cnki.com.cn. [2018-02-22]. (原始內容存檔於2018-04-19).
- ^ 对无线网络中Westwood拥塞控制算法的研究与改进--《华中师范大学》2016年硕士论文. cdmd.cnki.com.cn. [2018-02-22]. (原始內容存檔於2018-04-19).
- ^ The Cable Guy - November 2005. technet.microsoft.com. [2017-09-04]. (原始內容存檔於2013-06-21) (英語).
- ^ A hotfix that adds Compound TCP (CTCP) support to computers that are running Windows Server 2003 or Windows XP is available. [2018-04-19]. (原始內容存檔於2008-05-06).
- ^ Compound TCP in Linux. 2008-08-02 [2017-09-04]. (原始內容存檔於2008-08-02).
- ^ Proportional Rate Reduction for TCP. [2014-06-06]. (原始內容存檔於2014-07-14).
- ^ Corbet, Jonathan. LPC: Making the net go faster. [2014-06-06]. (原始內容存檔於2014-07-14).
- ^ Linux 3.2 - Linux Kernel Newbies. [2014-06-06]. (原始內容存檔於2014-07-03).
- ^ Delivery Rate Estimation. [2017-08-25]. (原始內容存檔於2018-04-19).
- ^ TCP BBR congestion control comes to GCP – your Internet just got faster. [2017-08-25]. (原始內容存檔於2017-08-25).
- ^ Increase your Linux server Internet speed with TCP BBR congestion control. nixCraft. [2017-11-25]. (原始內容存檔於2017-12-09) (美國英語).
- ^ Linux Kernel 4.9 Is Here, and It's the Largest Release Ever. Linux.com | The source for Linux information. [2017-11-25]. (原始內容存檔於2018-04-19) (英語).
- ^ TCP and BBR (PDF). [27 May 2018]. (原始內容存檔 (PDF)於2019-06-25).
- ^ Experimental Evaluation of BBR Congestion Control (PDF). [27 May 2018]. (原始內容存檔 (PDF)於2018-05-27).
- ^ 45.0 45.1 Abbasloo, S.; Xu, Y.; Chao, H. J. C2TCP: A Flexible Cellular TCP to Meet Stringent Delay Requirements. IEEE Journal on Selected Areas in Communications. 2019, 37 (4): 918–932. ISSN 0733-8716. arXiv:1810.13241 . doi:10.1109/JSAC.2019.2898758.
- ^ Abbasloo, S.; Li, T.; Xu, Y.; Chao, H. J. Cellular Controlled Delay TCP (C2TCP). 2018 IFIP Networking Conference and Workshops. May 2018: 118–126. Bibcode:2018arXiv180702689A. ISBN 978-3-903176-08-9. arXiv:1807.02689 . doi:10.23919/IFIPNetworking.2018.8696844.
外部連結
編輯- Approaches to Congestion Control in Packet Networks (PDF), [2018-04-19], (原始內容存檔 (PDF)於2014-02-21)
- 一些關於擁塞控制的論文(頁面存檔備份,存於網際網路檔案館)
- TCP Vegas的介紹首頁
- Mark Allman, Vern Paxson, W. Richard Stevens. Fast Retransmit/Fast Recovery. TCP Congestion Control. IETF. April 1999: sec. 3.2 [2010-05-01]. RFC 2581.
- TCP Congestion Handling and Congestion Avoidance Algorithms(頁面存檔備份,存於網際網路檔案館) – The TCP/IP Guide
- TCP的NewReno快速重傳和快速恢復演算法(頁面存檔備份,存於網際網路檔案館)
- TCP擁塞控制:Tahoe、Reno、NewReno與SACK演算法概述與比較(頁面存檔備份,存於網際網路檔案館)