分类: LINUX
2013-05-05 13:38:16
TCP/IP 协议栈中定义了MSS, 为的是提高网络的性能,因为如果让IP层分包的话,丢包后的重发没法控制,需要重传整个TCP包(浪费了网络资源)
MSS就是这个协商的结果,不能人为修改,这个MSS的大小是MTU减去TCP头,从TCPDUMP结果中我们可以看到我们的TCP协商的MSS都在1.3~1.4K
所以一定需要我们自己来重新组装TCP包的 (发送一个分拆一个TCP包对方收到也是一个分拆的TCP包,如果看底层还要复杂一些)
为了减少这种情况我们可以禁止NAGLE算法,设置一个TCP_NODELAY,但是只能说这个也只能减缓这个问题,因为其一,这个根本解决不了问题,其二,底层的SK_BUFF还是可能链接在一起的(发送速度不是无限的)è 如果不了解SK_BUFF建议看一下
所以如果一定要用TCP的话我们还是用模式来解决问题吧,The worker processor thread model就可以(有PPT不会上传,就这样吧)
或者就是用UDP包,因为UDP是用IP层来分包的,所以对于UDP层来说发一个大包,收到就是一个大包,但是IP层丢了包也不管,这样就需要应用层多一点校验,不过现在网络UDP丢包率已经很低了,所以也不是不可以考虑。
至于底层的内核怎么处理,网卡做什么事情后面再更新。