第 36 章 使用 TCP_NODELAY 提高网络延迟

默认情况下,TCP 使用 Nagle 的算法收集小的传出数据包以一次性发送所有。这可能导致延迟率更高。

先决条件

  • 管理员特权。

36.1. 使用 TCP_NODELAY 的效果

在启用 TCP_NODELAY 的套接字上,每个发送数据包需要低延迟的应用程序都必须在启用 TCP_NODELAY 的套接字上运行。这会在事件发生后马上向内核发送缓冲区写入。

请注意,为了让 TCP_NODELAY 生效,应用程序必须避免执行小型、逻辑相关的缓冲区写入操作。否则,这些小的写入会导致 TCP 发送这些缓冲区作为单个数据包,从而降低整体性能。

如果应用程序有多个与逻辑相关的缓冲,且必须以一个数据包发送,请应用以下临时解决方案之一以避免性能不佳:

  • 在内存中构建连续数据包,然后将逻辑数据包发送到使用 TCP_NODELAY 配置的套接字上的 TCP。
  • 在配置了 TCP_NODELAY 的套接字上创建一个 I/O vector,并使用 writev 命令将其传递给内核。
  • 使用 TCP_CORKTCP_CORK 告知 TCP 在发送任何数据包前等待应用程序删除 cork。该命令会导致它接收的缓冲区附加到现有缓冲区中。这使得应用程序可以在内核空间中构建数据包,在使用为层提供提取的不同库时,可能需要此数据包。

当应用程序中的各个组件在内核中构建逻辑数据包时,该套接字应该被取消标记,允许 TCP 立即发送累积的逻辑数据包。