您的位置:首页 > 理论基础 > 计算机网络

小数据包网络发送的优化策略

2009-06-04 17:26 274 查看
产品开发过程中,曾遇到过小数据包发送效率较低的情况(被延迟发送200ms),总结策略有三种:
策略1、使用
int flag = 1;
int result = setsockopt(sock, /* socket affected */
IPPROTO_TCP, /* set option at TCP level */
TCP_NODELAY, /* name of option */
(char *) &flag, /* the cast is historical cruft */
sizeof(int)); /* length of option value */
来屏蔽Negle算法,降低小包发送过程中200ms的延时现象,但可能造成系统整体的网络拥塞问题
java中,使用
socket.setTcpNoDelay(true);
策略2、代码中对小于1461的数据包进行补足(也就是填充一些垃圾数据),发送1461个数据长度,来降低小包发送过程中200ms的延时现象
策略3、修改操作系统的TCP核心参数,来达到方法一的效果,如AIX平台,可使用chdev -l en0 -a tcp_nodelay=1

注意:
1)策略2对于Java系列的socket通讯,应该也有同样的效果,一般来说推荐策略2
2)策略1和策略3在某些版本比较低的Unix上,可能不支持。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐