第26章 TCP_NODELAY を使用したネットワーク遅延の改善
デフォルトでは、TCP
は Nagle のアルゴリズムを使用して、小さな送信パケットを集めて一度に送信します。これにより、レイテンシーの発生率が高くなる可能性があります。
前提条件
- 管理者権限がある。
26.1. TCP_NODELAY の使用による影響
送信されるすべてのパケットでレイテンシーを低く保つ必要のあるアプリケーションは、TCP_NODELAY
オプションを有効化しているソケットで実行する必要があります。イベントが発生するとすぐに、カーネルにバッファー書き込みを送信します。
- 注記
-
TCP_NODELAY
を効果的に使用するには、アプリケーションが小規模な論理的に関連するバッファー書き込みを行わないようにする必要があります。これを行わないと、このような小さい書き込みにより、TCP
はこれらの複数のバッファーを個別のパケットとして送信するため、全体的なパフォーマンスが低下します。
論理に関連し、1 つのパケットとして送信する必要があるバッファーがアプリケーションに複数ある場合は、パフォーマンスの低下を回避するために、以下の回避策のいずれかを適用します。
-
メモリー内に連続したパケットを構築し、
TCP_NODELAY
で設定したソケット上で論理パケットをTCP
に送信する。 -
I/O ベクターを作成し、
TCP_NODELAY
で設定したソケット上でwritev
コマンドを使用してカーネルに渡す。 -
TCP_CORK
オプションを使用する。TCP_CORK
は、アプリケーションがコルクを削除するのを待ってからパケットを送信するようにTCP
に指示します。このコマンドにより、受信するバッファーが既存のバッファーに追加されます。これにより、アプリケーションはカーネル領域にパケットを構築できます。これは、レイヤーの抽象化を提供する異なるライブラリーを使用する場合は必要です。
アプリケーションのさまざまなコンポーネントにより、論理パケットがカーネルに構築されている場合は、ソケットのコルクを解除する必要があります。これにより、TCP
が、累積した論理パケットをすぐに送信できるようになります。