小数据包网络发送的优化策略
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上,可能不支持。
策略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上,可能不支持。
相关文章推荐
- 小数据包网络发送的优化策略
- 关于使用asio发送网络数据的优化。
- 网络编程_UDP协议发送和接收数据代码优化
- 网络相关系列之三:通过GET和POST方法发送数据
- 提交订单系统自动发送邮件到收件人邮箱优化(邮件正文内容为当天数据,附件内容为当月数据)
- C# 自己写的一个类,用来将结构体或类中的数据打成"数据包",进行网络发送(转载)
- C# 一个类用来将结构体或类中的数据打成"数据包",进行网络发送
- Android系列之网络(一)----使用HttpClient发送HTTP请求(通过get方法获取数据)
- udp协议的数据接收与发送的代码 分类: VC++ 网络基础 2014-02-25 08:15 700人阅读 评论(0) 收藏
- 主机网卡发现所发送数据的目的IP和默认网关不在同一网段(网络)时,会丢弃该数据帧吗???
- Android系列之网络(三)----使用HttpClient发送HTTP请求(分别通过GET和POST方法发送数据)
- 网络数据发送接收
- 网络——在网络上发送,接收数据
- ViaSat选择eXtremeDB来优化卫星和地面网络度量数据
- Android系列之网络(一)----使用HttpClient发送HTTP请求(通过get方法获取数据)
- Android系列之网络(三)----使用HttpClient发送HTTP请求(分别通过GET和POST方法发送数据)
- Android代码优化----PullToRefresh+universal-image-loader实现从网络获取数据并刷新
- 发送队列的默认队列策略 (linux网络子系统学习 第十一节 )
- Java_网络编程_使用UDP协议发送及接收数据
- Android系列之网络(一)----使用HttpClient发送HTTP请求(通过get方法获取数据)