[要約] RFC 9406 は、TCP の遅延開始フェーズを改善するための HyStart++ を説明しています。HyStart++ は、適切な送信レートを見つけるためにラウンドトリップ遅延の増加を利用し、パケットロスやパフォーマンスの低下を防ぎます。

Internet Engineering Task Force (IETF)                P. Balasubramanian
Request for Comments: 9406                                     Confluent
Category: Standards Track                                       Y. Huang
ISSN: 2070-1721                                                 M. Olson
                                                               Microsoft
                                                                May 2023
        
HyStart++: Modified Slow Start for TCP
Hystart:TCPの変更スロースタート
Abstract
概要

This document describes HyStart++, a simple modification to the slow start phase of congestion control algorithms. Slow start can overshoot the ideal send rate in many cases, causing high packet loss and poor performance. HyStart++ uses increase in round-trip delay as a heuristic to find an exit point before possible overshoot. It also adds a mitigation to prevent jitter from causing premature slow start exit.

このドキュメントでは、Hystartについて説明します。これは、うっ血制御アルゴリズムのスロースタートフェーズの単純な変更です。スロースタートは、多くの場合、理想的な送信率をオーバーシュートする可能性があり、高いパケット損失とパフォーマンスの低下を引き起こします。Hystartは、ヒューリスティックとして往復遅延の増加を使用して、オーバーシュートの前に出口ポイントを見つけます。また、ジッターが早期のスロースタート出口を引き起こすのを防ぐための緩和を追加します。

Status of This Memo
本文書の位置付け

This is an Internet Standards Track document.

これは、インターネット標準トラックドキュメントです。

This document is a product of the Internet Engineering Task Force (IETF). It represents the consensus of the IETF community. It has received public review and has been approved for publication by the Internet Engineering Steering Group (IESG). Further information on Internet Standards is available in Section 2 of RFC 7841.

このドキュメントは、インターネットエンジニアリングタスクフォース(IETF)の製品です。IETFコミュニティのコンセンサスを表しています。公開レビューを受けており、インターネットエンジニアリングステアリンググループ(IESG)からの出版が承認されています。インターネット標準の詳細については、RFC 7841のセクション2で入手できます。

Information about the current status of this document, any errata, and how to provide feedback on it may be obtained at https://www.rfc-editor.org/info/rfc9406.

このドキュメントの現在のステータス、任意のERRATA、およびそのフィードバックを提供する方法に関する情報は、https://www.rfc-editor.org/info/rfc9406で取得できます。

著作権表示

Copyright (c) 2023 IETF Trust and the persons identified as the document authors. All rights reserved.

著作権(c)2023 IETF Trustおよび文書著者として特定された人。無断転載を禁じます。

This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Code Components extracted from this document must include Revised BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Revised BSD License.

このドキュメントは、BCP 78およびIETFドキュメント(https://trustee.ietf.org/license-info)に関連するIETF Trustの法的規定の対象となります。この文書に関するあなたの権利と制限を説明するので、これらの文書を注意深く確認してください。このドキュメントから抽出されたコードコンポーネントには、セクション4.Eで説明されている法的規定のセクション4.Eで説明されており、改訂されたBSDライセンスで説明されている保証なしで提供されるように、改訂されたBSDライセンステキストを含める必要があります。

Table of Contents
目次
   1.  Introduction
   2.  Terminology
   3.  Definitions
   4.  HyStart++ Algorithm
     4.1.  Summary
     4.2.  Algorithm Details
     4.3.  Tuning Constants and Other Considerations
   5.  Deployments and Performance Evaluations
   6.  Security Considerations
   7.  IANA Considerations
   8.  References
     8.1.  Normative References
     8.2.  Informative References
   Acknowledgments
   Authors' Addresses
        
1. Introduction
1. はじめに

[RFC5681] describes the slow start congestion control algorithm for TCP. The slow start algorithm is used when the congestion window (cwnd) is less than the slow start threshold (ssthresh). During slow start, in the absence of packet loss signals, TCP increases the cwnd exponentially to probe the network capacity. This fast growth can overshoot the ideal sending rate and cause significant packet loss that cannot always be recovered efficiently.

[RFC5681]は、TCPのスロースタート輻輳制御アルゴリズムを説明しています。うっ血ウィンドウ(CWND)がスロースタートしきい値(SSTHRESH)よりも少ない場合、スロースタートアルゴリズムが使用されます。スロースタート中、パケット損失信号がない場合、TCPはCWNDを指数関数的に増加させてネットワーク容量をプローブします。この急速な成長は、理想的な送信率をオーバーシュートし、常に効率的に回復することはできない重大なパケット損失を引き起こす可能性があります。

HyStart++ builds upon Hybrid Start (HyStart), originally described in [HyStart]. HyStart++ uses increase in round-trip delay as a signal to exit slow start before potential packet loss occurs as a result of overshoot. This is one of two algorithms specified in [HyStart] for finding a safe exit point for slow start. After the slow start exit, a new Conservative Slow Start (CSS) phase is used to determine whether the slow start exit was premature and to resume slow start. This mitigation improves performance in the presence of jitter. HyStart++ reduces packet loss and retransmissions, and improves goodput in lab measurements and real-world deployments.

Hystartは、もともと[Hystart]で説明されているハイブリッドスタート(Hystart)に基づいています。Hystartは、オーバーシュートの結果として潜在的なパケット損失が発生する前に、潜在的なパケット損失が発生する前に、スロースタートを終了するための信号として、往復遅延の増加を使用します。これは、[Hystart]で指定された2つのアルゴリズムの1つであり、ゆっくりと開始するための安全な出口ポイントを見つけます。スロースタート出口の後、新しい保守的なスロースタート(CSS)フェーズを使用して、スロースタート出口が時期尚早であり、スロースタートを再開します。この緩和により、ジッターの存在下でのパフォーマンスが向上します。Hystartはパケットの損失と再送信を減らし、ラボの測定と現実世界の展開のGoodputを改善します。

While this document describes HyStart++ for TCP, it can also be used for other transport protocols that use slow start, such as QUIC [RFC9002] or the Stream Control Transmission Protocol (SCTP) [RFC9260].

このドキュメントでは、TCPのHystartについて説明していますが、QUIC [RFC9002]やストリーム制御伝送プロトコル(SCTP)[RFC9260]など、スロースタートを使用する他のトランスポートプロトコルにも使用できます。

2. Terminology
2. 用語

The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.

この文書のキーワード "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", および "OPTIONAL" はBCP 14 [RFC2119] [RFC8174]で説明されているように、すべて大文字の場合にのみ解釈されます。

3. Definitions
3. 定義

To aid the reader, we repeat some definitions from [RFC5681]:

読者を支援するために、[RFC5681]からいくつかの定義を繰り返します。

SENDER MAXIMUM SEGMENT SIZE (SMSS):

送信者最大セグメントサイズ(SMSS):

The size of the largest segment that the sender can transmit. This value can be based on the maximum transmission unit of the network, the Path MTU Discovery algorithm [RFC1191] [RFC4821], RMSS (see next item), or other factors. The size does not include the TCP/IP headers and options.

送信者が送信できる最大のセグメントのサイズ。この値は、ネットワークの最大送信ユニット、PATH MTU Discoveryアルゴリズム[RFC1191] [RFC4821]、RMSS(次のアイテムを参照)、またはその他の要因に基づいています。サイズには、TCP/IPヘッダーとオプションは含まれません。

RECEIVER MAXIMUM SEGMENT SIZE (RMSS):

受信機の最大セグメントサイズ(RMSS):

The size of the largest segment that the receiver is willing to accept. This is the value specified in the MSS option sent by the receiver during connection startup. Or, if the MSS option is not used, it is 536 bytes [RFC1122]. The size does not include the TCP/IP headers and options.

受信者が喜んで受け入れる最大のセグメントのサイズ。これは、接続スタートアップ中に受信機が送信したMSSオプションで指定された値です。または、MSSオプションを使用していない場合、536バイト[RFC1122]です。サイズには、TCP/IPヘッダーとオプションは含まれません。

RECEIVER WINDOW (rwnd):

受信ウィンドウ(RWND):

The most recently advertised receiver window.

最近宣伝されているレシーバーウィンドウ。

CONGESTION WINDOW (cwnd):

混雑ウィンドウ(CWND):

A TCP state variable that limits the amount of data a TCP can send. At any given time, a TCP MUST NOT send data with a sequence number higher than the sum of the highest acknowledged sequence number and the minimum of the cwnd and rwnd.

TCPが送信できるデータの量を制限するTCP状態変数。いつでも、TCPは、CWNDおよびRWNDの最低値と最小値の合計よりも高いシーケンス番号を持つデータを送信してはなりません。

4. HyStart++ Algorithm
4. Hystartアルゴリズム
4.1. Summary
4.1. まとめ

[HyStart] specifies two algorithms (a "Delay Increase" algorithm and an "Inter-Packet Arrival" algorithm) to be run in parallel to detect that the sending rate has reached capacity. In practice, the Inter-Packet Arrival algorithm does not perform well and is not able to detect congestion early, primarily due to ACK compression. The idea of the Delay Increase algorithm is to look for spikes in RTT (round-trip time), which suggest that the bottleneck buffer is filling up.

[Hystart] 2つのアルゴリズム(「遅延増加」アルゴリズムと「パケット間到着」アルゴリズム)を並行して実行して、送信率が容量に達したことを検出します。実際には、パケット間到着アルゴリズムはうまく機能せず、主にACK圧縮のために輻輳を早期に検出することができません。遅延増加アルゴリズムのアイデアは、RTT(往復時間)のスパイクを探すことです。これは、ボトルネックバッファがいっぱいになっていることを示唆しています。

In HyStart++, a TCP sender uses standard slow start and then uses the Delay Increase algorithm to trigger an exit from slow start. But instead of going straight from slow start to congestion avoidance, the sender spends a number of RTTs in a Conservative Slow Start (CSS) phase to determine whether the exit from slow start was premature. During CSS, the congestion window is grown exponentially in a fashion similar to regular slow start, but with a smaller exponential base, resulting in less aggressive growth. If the RTT reduces during CSS, it's concluded that the RTT spike was not related to congestion caused by the connection sending at a rate greater than the ideal send rate, and the connection resumes slow start. If the RTT inflation persists throughout CSS, the connection enters congestion avoidance.

Hystartでは、TCP Senderが標準のスロースタートを使用し、遅延増加アルゴリズムを使用してスロースタートからの出口をトリガーします。しかし、スロースタートから混雑回避に直接進む代わりに、送信者は保守的なスロースタート(CSS)フェーズで多くのRTTを費やして、スロースタートからの出口が時期尚早かどうかを判断します。CSSの間、輻輳ウィンドウは、通常のスロースタートと同様に形で指数関数的に成長しますが、指数ベースが小さく、攻撃的な成長が少なくなります。RTTがCSS中に減少した場合、RTTスパイクは、理想的な送信レートよりも大きいレートで接続の送信によって引き起こされる混雑とは関係がなく、接続がスロースタートを再開すると結論付けられています。RTTのインフレがCSS全体で持続している場合、接続は混雑回避に入ります。

4.2. Algorithm Details
4.2. アルゴリズムの詳細

The following pseudocode uses a limit, L, to control the aggressiveness of the cwnd increase during both standard slow start and CSS. While an arriving ACK may newly acknowledge an arbitrary number of bytes, the HyStart++ algorithm limits the number of those bytes applied to increase the cwnd to L*SMSS bytes.

次の擬似コードは、制限lを使用して、標準のスロースタートとCSSの両方の間にCWND増加の攻撃性を制御します。到着するACKは任意の数のバイトを新たに認めている可能性がありますが、ハイスタートアルゴリズムは、CWNDをL*SMSSバイトに増やすために適用されるバイトの数を制限します。

lastRoundMinRTT and currentRoundMinRTT are initialized to infinity at the initialization time. currRTT is the RTT sampled from the latest incoming ACK and initialized to infinity.

lastroundminrttおよびcurrentRoundMinrttは、初期化時に無限に初期化されます。Currrttは、最新の着信ACKからサンプリングされ、Infinityに初期化されたRTTです。

   lastRoundMinRTT = infinity
   currentRoundMinRTT = infinity
   currRTT = infinity
        

HyStart++ measures rounds using sequence numbers, as follows:

次のように、Hystartはシーケンス番号を使用してラウンドを測定します。

* Define windowEnd as a sequence number initialized to SND.NXT.

* WindowEndをSND.NXTに初期化されたシーケンス番号として定義します。

* When windowEnd is ACKed, the current round ends and windowEnd is set to SND.NXT.

* WindowEndがAckedを使用すると、現在のラウンドが終了し、WindowEndはsnd.nxtに設定されます。

At the start of each round during standard slow start [RFC5681] and CSS, initialize the variables used to compute the last round's and current round's minimum RTT:

標準のスロースタート[RFC5681]およびCSS中の各ラウンドの開始時に、最後のラウンドと現在のラウンドの最小RTTを計算するために使用される変数を初期化します。

   lastRoundMinRTT = currentRoundMinRTT
   currentRoundMinRTT = infinity
   rttSampleCount = 0
        

For each arriving ACK in slow start, where N is the number of previously unacknowledged bytes acknowledged in the arriving ACK:

スロースタートでACKが到着するたびに、nは到着したACKで認められた以前に承認されていないバイトの数です。

Update the cwnd:

CWNDを更新します:

     cwnd = cwnd + min(N, L * SMSS)
        

Keep track of the minimum observed RTT:

観測された最小のRTTを追跡します:

     currentRoundMinRTT = min(currentRoundMinRTT, currRTT)
     rttSampleCount += 1
        

For rounds where at least N_RTT_SAMPLE RTT samples have been obtained and currentRoundMinRTT and lastRoundMinRTT are valid, check to see if delay increase triggers slow start exit:

少なくともN_RTT_SAMPLE RTTサンプルが取得されており、CurrentRoundMinRTTとLastRoundMinRTTが有効なラウンドの場合、遅延増加トリガーが遅い開始出口を増やすかどうかを確認してください。

   if ((rttSampleCount >= N_RTT_SAMPLE) AND
       (currentRoundMinRTT != infinity) AND
       (lastRoundMinRTT != infinity))
     RttThresh = max(MIN_RTT_THRESH,
       min(lastRoundMinRTT / MIN_RTT_DIVISOR, MAX_RTT_THRESH))
     if (currentRoundMinRTT >= (lastRoundMinRTT + RttThresh))
       cssBaselineMinRtt = currentRoundMinRTT
       exit slow start and enter CSS
        

For each arriving ACK in CSS, where N is the number of previously unacknowledged bytes acknowledged in the arriving ACK:

CSSに到着するACKごとに、Nは到着したACKで認められていた以前の未把持バイトの数です。

Update the cwnd:

CWNDを更新します:

   cwnd = cwnd + (min(N, L * SMSS) / CSS_GROWTH_DIVISOR)
        

Keep track of the minimum observed RTT:

観測された最小のRTTを追跡します:

   currentRoundMinRTT = min(currentRoundMinRTT, currRTT)
   rttSampleCount += 1
        

For CSS rounds where at least N_RTT_SAMPLE RTT samples have been obtained, check to see if the current round's minRTT drops below baseline (cssBaselineMinRtt) indicating that slow start exit was spurious:

少なくともN_RTT_Sample RTTサンプルが取得されているCSSラウンドの場合、現在のラウンドのMinRTTがベースライン(CSSBaseLineminRTT)の下にドロップするかどうかを確認して、スロースタートの出口が偽りであることを示しています。

   if (currentRoundMinRTT < cssBaselineMinRtt)
     cssBaselineMinRtt = infinity
     resume slow start including HyStart++
        

CSS lasts at most CSS_ROUNDS rounds. If the transition into CSS happens in the middle of a round, that partial round counts towards the limit.

CSSはほとんどのCSS_ROUNDSラウンドで持続します。CSSへの移行がラウンドの途中で発生した場合、その部分ラウンドは限界にカウントされます。

If CSS_ROUNDS rounds are complete, enter congestion avoidance by setting the ssthresh to the current cwnd.

CSS_Roundsラウンドが完了した場合は、SSTHRESHを現在のCWNDに設定して、混雑回避を入力します。

   ssthresh = cwnd
        

If loss or Explicit Congestion Notification (ECN) marking is observed at any time during standard slow start or CSS, enter congestion avoidance by setting the ssthresh to the current cwnd.

標準のスロースタートまたはCSS中にいつでも紛失または明示的な混雑通知(ECN)マーキングが観察される場合、SSThreshを現在のCWNDに設定することにより、混雑回避を入力します。

   ssthresh = cwnd
        
4.3. Tuning Constants and Other Considerations
4.3. チューニング定数およびその他の考慮事項

It is RECOMMENDED that a HyStart++ implementation use the following constants:

Hystart実装では、次の定数を使用することをお勧めします。

   MIN_RTT_THRESH = 4 msec
   MAX_RTT_THRESH = 16 msec
   MIN_RTT_DIVISOR = 8
   N_RTT_SAMPLE = 8
   CSS_GROWTH_DIVISOR = 4
   CSS_ROUNDS = 5
   L = infinity if paced, L = 8 if non-paced
        

These constants have been determined with lab measurements and real-world deployments. An implementation MAY tune them for different network characteristics.

これらの定数は、実験室の測定と現実世界の展開で決定されています。実装は、異なるネットワーク特性に対してそれらをチューニングする場合があります。

The delay increase sensitivity is determined by MIN_RTT_THRESH and MAX_RTT_THRESH. Smaller values of MIN_RTT_THRESH may cause spurious exits from slow start. Larger values of MAX_RTT_THRESH may result in slow start not exiting until loss is encountered for connections on large RTT paths.

遅延の増加感度は、min_rtt_threshおよびmax_rtt_threshによって決定されます。min_rtt_threshの値が小さい場合は、スロースタートからスプリアスエックスを引き起こす可能性があります。MAX_RTT_THRESHの値が大きくなると、大きなRTTパスでの接続の損失が発生するまで、ゆっくりと開始しない場合があります。

MIN_RTT_DIVISOR is a fraction of RTT to compute the delay threshold. A smaller value would mean a larger threshold and thus less sensitivity to delay increase, and vice versa.

min_rtt_divisorは、遅延しきい値を計算するためのRTTのほんの一部です。値が小さくなると、しきい値が大きくなり、遅延増加に対する感度が低くなり、逆も同様です。

While all TCP implementations are REQUIRED to take at least one RTT sample each round, implementations of HyStart++ are RECOMMENDED to take at least N_RTT_SAMPLE RTT samples. Using lower values of N_RTT_SAMPLE will lower the accuracy of the measured RTT for the round; higher values will improve accuracy at the cost of more processing.

すべてのTCP実装は、少なくとも1つのRTTサンプルを各ラウンドで採取するために必要ですが、Hystartの実装は、少なくともN_RTT_SAMPLE RTTサンプルを採取することをお勧めします。N_RTT_SAMPLEの低い値を使用すると、ラウンドの測定されたRTTの精度が低下します。値が高いと、より多くの処理の犠牲を払って精度が向上します。

The minimum value of CSS_GROWTH_DIVISOR MUST be at least 2. A value of 1 results in the same aggressive behavior as regular slow start. Values larger than 4 will cause the algorithm to be less aggressive and maybe less performant.

CSS_GROWTH_DIVISORの最小値は、少なくとも2でなければなりません。4を超える値により、アルゴリズムの攻撃性が低く、パフォーマンスが低下します。

Smaller values of CSS_ROUNDS may miss detecting jitter, and larger values may limit performance.

CSS_ROUNDSの値が少ない場合は、ジッターの検出を見逃し、値が大きいとパフォーマンスが制限される場合があります。

Packet pacing [ASA00] is a possible mechanism to avoid large bursts and their associated harm. A paced TCP implementation SHOULD use L = infinity. Burst concerns are mitigated by pacing, and this setting allows for optimal cwnd growth on modern networks.

パケットペース[ASA00]は、大きなバーストとそれに関連する害を避けるための可能なメカニズムです。ペースのTCP実装では、L = Infinityを使用する必要があります。バーストの懸念はペーシングによって軽減され、この設定により、最新のネットワークで最適なCWND成長が可能になります。

For TCP implementations that pace to mitigate burst concerns, L values smaller than infinity may suffer performance problems due to slow cwnd growth in high-speed networks. For non-paced TCP implementations, L values smaller than 8 may suffer performance problems due to slow cwnd growth in high-speed networks; L values larger than 8 may cause an increase in burstiness and thereby loss rates, and result in poor performance.

バーストの懸念を緩和するペースを持つTCP実装の場合、高速ネットワークのCWND成長が遅いため、無限よりも小さい値がパフォーマンスの問題に苦しむ可能性があります。ペースのないTCP実装の場合、L値は8未満の値が高速ネットワークのCWND成長が遅いためパフォーマンスの問題に苦しむ可能性があります。l値が8を超える値は、バーストの増加とそれによって損失率の増加を引き起こし、パフォーマンスが低下する可能性があります。

An implementation SHOULD use HyStart++ only for the initial slow start (when the ssthresh is at its initial value of arbitrarily high per [RFC5681]) and fall back to using standard slow start for the remainder of the connection lifetime. This is acceptable because subsequent slow starts will use the discovered ssthresh value to exit slow start and avoid the overshoot problem. An implementation MAY use HyStart++ to grow the restart window [RFC5681] after a long idle period.

実装では、最初のスロースタートでのみHystartを使用する必要があります(SSthreshが[RFC5681]ごとに任意に高くなっている初期値がある場合)。これは、その後のスロースタートが発見されたSSThresh値を使用してスロースタートを終了し、オーバーシュートの問題を回避するため、許容されます。実装では、長いアイドル期間の後にハイスタートを使用して再起動ウィンドウ[RFC5681]を栽培する場合があります。

In application-limited scenarios, the amount of data in flight could fall below the bandwidth-delay product (BDP) and result in smaller RTT samples, which can trigger an exit back to slow start. It is expected that a connection might oscillate between CSS and slow start in such scenarios. But this behavior will neither result in a connection prematurely entering congestion avoidance nor cause overshooting compared to slow start.

アプリケーションに制限されたシナリオでは、飛行中のデータの量は帯域幅遅延製品(BDP)を下回り、RTTサンプルが小さくなり、出口をトリガーしてスロースタートをトリガーできます。このようなシナリオでは、接続がCSSの間で振動し、スロースタートが発生する可能性があります。しかし、この動作は、ゆっくりとしたスタートと比較して、混合回避を早期に接続したり、オーバーシュートを引き起こすこともありません。

5. Deployments and Performance Evaluations
5. 展開とパフォーマンス評価

At the time of this writing, HyStart++ as described in this document has been default enabled for all TCP connections in the Windows operating system for over two years with pacing disabled and an actual L = 8.

この執筆時点で、このドキュメントで説明されているようにHystartは、WindowsオペレーティングシステムのすべてのTCP接続に対して2年以上にわたってデフォルトが有効になっており、ペーシング障害と実際のL = 8があります。

In lab measurements with Windows TCP, HyStart++ shows goodput improvements as well as reductions in packet loss and retransmissions compared to standard slow start. For example, across a variety of tests on a 100 Mbps link with a bottleneck buffer size of bandwidth-delay product, HyStart++ reduces bytes retransmitted by 50% and retransmission timeouts (RTOs) by 36%.

Windows TCPを使用したラボ測定では、Hystartは、標準の遅いスタートと比較して、パケットの損失と再送信の削減と同様に、グッドポットの改善と削減を示しています。たとえば、帯域幅遅延製品のボトルネックバッファーサイズを使用した100 Mbpsリンクのさまざまなテストで、Hystartは50%の再送信バイトと再送信タイムアウト(RTO)を36%削減します。

In an A/B test where we compared an implementation of HyStart++ (based on an earlier draft version of this document) to standard slow start across a large Windows device population, out of 52 billion TCP connections, 0.7% of connections move from 1 RTO to 0 RTOs and another 0.7% of connections move from 2 RTOs to 1 RTO with HyStart++. This test did not focus on send-heavy connections, and the impact on send-heavy connections is likely much higher. We plan to conduct more such production experiments to gather more data in the future.

A/Bテストでは、Hystartの実装(このドキュメントの以前のドラフトバージョンに基づく)を比較して、520億のTCP接続のうち、1つのRTOから0.7%が移動する大規模なWindowsデバイス母集団にわたって標準のスロースタートと比較しました。0 rtosと、接続の別の0.7%が2 rtosからHystartを使用して1 RTOに移動します。このテストでは、送信が多い接続に焦点を当てておらず、送信が多い接続への影響ははるかに高い可能性があります。将来、より多くのデータを収集するために、このような生産実験を実施する予定です。

6. Security Considerations
6. セキュリティに関する考慮事項

HyStart++ enhances slow start and inherits the general security considerations discussed in [RFC5681].

Hystartはスロースタートを強化し、[RFC5681]で説明した一般的なセキュリティ上の考慮事項を継承します。

An attacker can cause HyStart++ to exit slow start prematurely and impair the performance of a TCP connection by, for example, dropping data packets or their acknowledgments.

攻撃者は、ハイスタートが早期にスタートスタートを終了し、たとえばデータパケットやその謝辞を削除することにより、TCP接続のパフォーマンスを損なう可能性があります。

The ACK division attack outlined in [SCWA99] does not affect HyStart++ because the congestion window increase in HyStart++ is based on the number of bytes newly acknowledged in each arriving ACK rather than by a particular constant on each arriving ACK.

[SCWA99]で概説されているACK部門攻撃は、ハイスタートの混雑ウィンドウの増加は、到着する各ACKで特定の定数ではなく、到着する各ACKで新たに認められているバイト数に基づいているため、ハイスタートに影響しません。

7. IANA Considerations
7. IANAの考慮事項

This document has no IANA actions.

このドキュメントにはIANAアクションがありません。

8. References
8. 参考文献
8.1. Normative References
8.1. 引用文献
   [RFC2119]  Bradner, S., "Key words for use in RFCs to Indicate
              Requirement Levels", BCP 14, RFC 2119,
              DOI 10.17487/RFC2119, March 1997,
              <https://www.rfc-editor.org/info/rfc2119>.
        
   [RFC5681]  Allman, M., Paxson, V., and E. Blanton, "TCP Congestion
              Control", RFC 5681, DOI 10.17487/RFC5681, September 2009,
              <https://www.rfc-editor.org/info/rfc5681>.
        
   [RFC8174]  Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC
              2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174,
              May 2017, <https://www.rfc-editor.org/info/rfc8174>.
        
8.2. Informative References
8.2. 参考引用
   [ASA00]    Aggarwal, A., Savage, S., and T. Anderson, "Understanding
              the performance of TCP pacing", Proceedings IEEE INFOCOM
              2000, DOI 10.1109/INFCOM.2000.832483, March 2000,
              <https://doi.org/10.1109/INFCOM.2000.832483>.
        
   [HyStart]  Ha, S. and I. Rhee, "Taming the elephants: New TCP slow
              start", Computer Networks vol. 55, no. 9, pp. 2092-2110,
              DOI 10.1016/j.comnet.2011.01.014, June 2011,
              <https://doi.org/10.1016/j.comnet.2011.01.014>.
        
   [RFC1122]  Braden, R., Ed., "Requirements for Internet Hosts -
              Communication Layers", STD 3, RFC 1122,
              DOI 10.17487/RFC1122, October 1989,
              <https://www.rfc-editor.org/info/rfc1122>.
        
   [RFC1191]  Mogul, J. and S. Deering, "Path MTU discovery", RFC 1191,
              DOI 10.17487/RFC1191, November 1990,
              <https://www.rfc-editor.org/info/rfc1191>.
        
   [RFC4821]  Mathis, M. and J. Heffner, "Packetization Layer Path MTU
              Discovery", RFC 4821, DOI 10.17487/RFC4821, March 2007,
              <https://www.rfc-editor.org/info/rfc4821>.
        
   [RFC9002]  Iyengar, J., Ed. and I. Swett, Ed., "QUIC Loss Detection
              and Congestion Control", RFC 9002, DOI 10.17487/RFC9002,
              May 2021, <https://www.rfc-editor.org/info/rfc9002>.
        
   [RFC9260]  Stewart, R., Tüxen, M., and K. Nielsen, "Stream Control
              Transmission Protocol", RFC 9260, DOI 10.17487/RFC9260,
              June 2022, <https://www.rfc-editor.org/info/rfc9260>.
        
   [SCWA99]   Savage, S., Cardwell, N., Wetherall, D., and T. Anderson,
              "TCP congestion control with a misbehaving receiver", ACM
              SIGCOMM Computer Communication Review, vol. 29, issue 5,
              pp. 71-78, DOI 10.1145/505696.505704, October 1999,
              <https://doi.org/10.1145/505696.505704>.
        
Acknowledgments
謝辞

During the discussions of this work on the TCPM mailing list and in working group meetings, helpful comments, critiques, and reviews were received from (listed alphabetically by last name) Mark Allman, Bob Briscoe, Neal Cardwell, Yuchung Cheng, Junho Choi, Martin Duke, Reese Enghardt, Christian Huitema, Ilpo Järvinen, Yoshifumi Nishida, Randall Stewart, and Michael Tüxen.

TCPMメーリングリストとワーキンググループ会議でのこの作業の議論の中で、有益なコメント、批評、レビューは(姓ごとにアルファベット順にリストされています)Mark Allman、Bob Briscoe、Neal Cardwell、Yuchung Cheng、Junho Choi、Martininデューク、リース・エンガルト、クリスチャン・フイテマ、イルポ・イェルビネン、ヨシフミ・ヨシフミダ、ランドール・スチュワート、マイケル・チューセン。

Authors' Addresses
著者のアドレス
   Praveen Balasubramanian
   Confluent
   899 West Evelyn Ave
   Mountain View, CA 94041
   United States of America
   Email: pravb.ietf@gmail.com
        
   Yi Huang
   Microsoft
   One Microsoft Way
   Redmond, WA 98052
   United States of America
   Phone: +1 425 703 0447
   Email: huanyi@microsoft.com
        
   Matt Olson
   Microsoft
   One Microsoft Way
   Redmond, WA 98052
   United States of America
   Phone: +1 425 538 8598
   Email: maolson@microsoft.com