18-TCP 协议(迟到的 ACK—— Linux)

在上一篇文章中已经分析了 windows 在回复确认时的情况,在接收到 TCP 段的情况下,等待 200ms 再回复 ack,除非在这 200ms 里接收方也有数据要发给对方,于是就在发送数据的时候将 ack 捎带过去。

本文我们分析 Linux 中的情况,我使用的是 Unbutu 14.4.

1. 实验

1.1 实验步骤

  • 服务器 unp/protocol/tools/winserver/tcp_server.cpp,部署在 windows 上。
  • 客户端 unp/protocol/tools/tcpclient/echo_cli.c,部署在 Linux 上。

  • 启动 tcp_server

tcp_server.exe 192.168.80.2 8000
  • 在 Linux 中启动 tcpdump
$ sudo tcpdump port 8000
  • 在 Linux 中启动客户端
$ ./echo_cli 192.168.80.2 8000

然后随便输入一些字符。

1.2 tcpdump 结果


这里写图片描述
图1 tcpdump 抓的包

图 1 是我截取的部分数据,红色和蓝色框框中的第二行,表示对服务器回显的数据进行确认。

红色框框中的确认是有延时的,即 delayed ack,而蓝色框框中的 ack 几乎都是在收到数据后立即发送出去的。

另外注意,所有的延时的 ack,延时时间都在 40 ms 左右(从收到数据到发送 ack 之间的时间)。

按照官方的说法:

当协议栈接受到TCP数据时,并不一定会立刻发送ACK响应,而是倾向于等待一个超时或者满足特殊条件时再发送。对于Linux实现,这些特殊条件如下:

1)收到的数据已经超过了 full frame size
2)或者处于快速回复模式
3)或者出现了乱序的包
4)或者接收窗口的数据足够多

如果接收方有数据回写,则ACK也会搭车一起发送。当以上条件都不满足时,接收方会延迟40ms再回应ACK。

然而在图 1 中,很多立刻回送的 ack 并不满足上述条件。也许是内核中 TCP 协议栈的策略有所改变吧……

2. 关于延时的 ack

有时候,我们不希望 ack 被延时发送,可以设置 TCP_QUICKACK(>Linux 2.4.4)。另外,delay ack 会对 nagle 算法造成影响,导致数据传输速率变慢。关于 nagle 算法,后面会有分析。

3. 总结

  • Linux 中的 delayed ack
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
要优化 Linux 内核以减少 TCP 重传和重复确认问题,可以尝试以下方法: 1. 调整 TCP 参数:可以通过修改内核参数来调整 TCP 的行为。一些相关的参数包括: - tcp_retries1 和 tcp_retries2:控制 TCP 重传的次数。可以适度增加这两个参数的值,以允许更多次的重传尝试。 - tcp_syn_retries:控制 TCP 建立连接时的重传次数。同样,适度增加该参数的值可以增加重传次数。 - tcp_keepalive_time:设置 TCP 连接的空闲时间,超过该时间后会发送 keepalive 报文以保持连接。适当调整该参数可以减少连接超时导致的重传。 - tcp_timestamps:启用 TCP 时间戳选项,可以减少重传和重复确认的问题。 2. 启用 SACK(Selective Acknowledgment):SACK 可以使 TCP 在接收到乱序报文时,只对缺失的报文进行重传,而不是对整个连续的报文段进行重传。在内核中启用 SACK 可以减少不必要的重传和重复确认。 3. 调整 TCP 拥塞控制算法:Linux 内核提供了多种拥塞控制算法,如 Reno、Cubic、BIC 等。不同的算法可能适用于不同的网络环境和负载条件。可以尝试切换拥塞控制算法来优化 TCP 的性能和减少重传问题。 4. 更新内核版本:及时更新 Linux 内核版本,以获取更好的 TCP 实现和修复已知的问题。新版本的内核通常会对 TCP 进行改进和优化。 5. 检查网络设备和链路:确保网络设备(如网卡、交换机、路由器)的驱动程序和固件是最新版本,并检查链路的稳定性和性能。有时,问题可能出现在网络设备或链路上,而不是在内核本身。 6. 使用专业的网络优化工具:有一些专业的网络优化工具可用于调整和优化 TCP 参数,例如 sysctl、tune2fs、ethtool 等。这些工具可以提供更精细的控制和配置选项。 需要注意的是,优化内核时应该谨慎操作,并在测试环境中进行验证。不同的应用程序和网络环境可能需要不同的优化策略。建议在进行任何更改之前备份重要的配置文件和系统状态,并监控性能变化以确保优化的有效性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值