Chinaunix首页 | 论坛 | 博客
  • 博客访问: 378393
  • 博文数量: 105
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 826
  • 用 户 组: 普通用户
  • 注册时间: 2013-02-16 13:58
个人简介

记录有意义的东西

文章分类

全部博文(105)

文章存档

2013年(105)

我的朋友

分类: LINUX

2013-05-05 13:38:16

TCP/IP 协议栈中定义了MSS, 为的是提高网络的性能,因为如果让IP层分包的话,丢包后的重发没法控制,需要重传整个TCP包(浪费了网络资源)

MSS就是这个协商的结果,不能人为修改,这个MSS的大小是MTU减去TCP头,从TCPDUMP结果中我们可以看到我们的TCP协商的MSS都在1.31.4K

 

所以一定需要我们自己来重新组装TCP包的 (发送一个分拆一个TCP包对方收到也是一个分拆的TCP包,如果看底层还要复杂一些)

为了减少这种情况我们可以禁止NAGLE算法,设置一个TCP_NODELAY,但是只能说这个也只能减缓这个问题,因为其一,这个根本解决不了问题,其二,底层的SK_BUFF还是可能链接在一起的(发送速度不是无限的)è 如果不了解SK_BUFF建议看一下

 

所以如果一定要用TCP的话我们还是用模式来解决问题吧,The worker processor thread model就可以(有PPT不会上传,就这样吧)


或者就是用UDP包,因为UDP是用IP层来分包的,所以对于UDP层来说发一个大包,收到就是一个大包,但是IP层丢了包也不管,这样就需要应用层多一点校验,不过现在网络UDP丢包率已经很低了,所以也不是不可以考虑。

 

至于底层的内核怎么处理,网卡做什么事情后面再更新
阅读(1903) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~