linux 查看路径mtu,TCP_MAXSEG不准确? (是:Linux路径MTU探测不在accept()上工作:如果使用setsockopt()请求ed socket;...

问题更新:除了下面的问题,似乎我们使用Linux PLPMTUD机制的客户端/服务器应用程序获得了太大的路径MTU。有没有人看过这个,即实际路径MTU是1500,但是getockopt w TCP_MAXSEG返回端点的MTU:s,在我们的例子中是3000?我试过用ethtool转换GRO,GSO和TSO,但错误仍然存​​在。普通ping只能设法推送1472字节或更小的数据包。另外值得一提的是PLPMTUD适用于较小的MTU:s。例如,在1500 MTU的w端点和中间路由器的一个接口设置为例如1200 MTU,内核TCP探测并报告正确的TCP_MAXSEG(1200 - 报头)。

我在应用程序中使用符合Linux RFC4821的分组层路径MTU发现。基本上,客户端在TCP套接字上执行setsockopt:

setsockopt(fd,SOL_IP,IP_MTU_DISCOVER,& sopt,sizeof(sopt))

选项值设置为IP_PMTUDISC_PROBE。 setsockopt不会返回错误。

客户端向丢弃服务器发送大型tcp数据包,路径MTU由Linux内核校准 - tcpdump显示发送DF位设置的tcp数据包,数据包大小不同,直到内核知道路径MTU。但是,要使其在另一个方向上工作(侦听服务器接受:来自客户端的连接,发送数据和从服务器到客户端的方向校准PMTU)我必须为tcp路径mtu发现设置全局选项,/ proc / sys / NET /支持IPv4 / tcp_mtu_probing。如果不这样做,服务器将愚蠢地继续发送过大的数据包,这些数据包会被没有ICMP发送回的中间路由器丢弃。两个端点的MTU设置为3000,而中间跃点的MTU设置为1500.

我希望有人知道出了什么问题。如果需要更多信息,请告诉我并编辑问题。 Linux内核4.2.0和3.19.0都存在问题,两者都是库存Kubuntu LTS内核。 (86 / x86-64的)

我在所有accept:ed套接字上设置了相同的套接字选项服务器端,然后以反方向发送数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值