socket缓冲区大小
来源:互联网 发布:windows开机更新失败 编辑:程序博客网 时间:2024/05/16 01:11
socket缓冲区大小默认为64 k
理论上最优大小为 带宽乘以往返时间(RTT通过ping ip地址的最后一行得到,如下图所示)
一般把缓冲区大小的最优化设置需要参照带宽与往返时间RTT得到的带宽延迟BDP。
假设应用程序是通过一个 100Mbps 的局域网进行通信,其 RTT 为 10 ms,那么 BDP 就是:
100MBps * 0.010 sec / 8 = 3.125MB = 3125KB
如要设置socket缓冲区大小为1M(具体根据你的BDP值),有最大接受/发送与默认接收/发送4个设置:
但是默认为64KB,要设置超过64KB的缓冲区大小必须启用 RFC 1323 定义的 window scaling:
/proc/sys/net/ipv4/tcp_window_scaling "1"
因为带宽是固定的,但RTT受实际影响比较大,如果要精细定义,则必须启用RFC 1323的如下方法
/proc/sys/net/ipv4/tcp_timestamps "1"
然后是主要的四个参数设置:
//最大接收
sysctl -w net.core.rmem_max=1048576
//最大发送
sysctl -w net.core.rmem_max=1048576
//默认的话把上面的max改为default即可
查看缓冲区设置参数,进proc/sys目录运行:
sysctl -p | grep mem
理论上最优大小为 带宽乘以往返时间(RTT通过ping ip地址的最后一行得到,如下图所示)
一般把缓冲区大小的最优化设置需要参照带宽与往返时间RTT得到的带宽延迟BDP。
假设应用程序是通过一个 100Mbps 的局域网进行通信,其 RTT 为 10 ms,那么 BDP 就是:
100MBps * 0.010 sec / 8 = 3.125MB = 3125KB
如要设置socket缓冲区大小为1M(具体根据你的BDP值),有最大接受/发送与默认接收/发送4个设置:
但是默认为64KB,要设置超过64KB的缓冲区大小必须启用 RFC 1323 定义的 window scaling:
/proc/sys/net/ipv4/tcp_window_scaling "1"
因为带宽是固定的,但RTT受实际影响比较大,如果要精细定义,则必须启用RFC 1323的如下方法
/proc/sys/net/ipv4/tcp_timestamps "1"
然后是主要的四个参数设置:
//最大接收
sysctl -w net.core.rmem_max=1048576
//最大发送
sysctl -w net.core.rmem_max=1048576
//默认的话把上面的max改为default即可
查看缓冲区设置参数,进proc/sys目录运行:
sysctl -p | grep mem
- 设置socket缓冲区大小
- socket缓冲区大小设置
- socket缓冲区大小设置
- 设置socket缓冲区大小
- socket缓冲区大小
- 设置socket缓冲区大小
- socket缓冲区大小 .
- socket 缓冲区大小设置
- 获得socket的缓冲区大小
- linux socket 缓冲区默认大小
- linux 默认socket 缓冲区大小
- 设置Socket缓冲区的大小
- unix socket 的缓冲区大小
- linux socket 缓冲区默认大小
- linux socket 缓冲区默认大小
- linux socket 缓冲区默认大小
- socket tcp缓冲区大小的默认值、最大值
- C++/socket缓冲区的大小设置
- PHP实现计划任务的几种方法
- Android 避免bitmap内存限制
- iOS开发 -xcode真机测试详细步骤
- 哈佛大学凌晨4点半的景象
- 关于JavaScript中apply与call的用法意义及区别
- socket缓冲区大小
- PeopleCode调用CI
- 点滴记录之-android定期备份项目版本
- 在UltraEdit中为SQR配置代码着色
- DMA_ZONE、dma_mask、coherent_dma_mask和dma bounce相关问题的澄清
- 明晰C++内存分配的五种方法的区别
- 类帮助器(动态生成类 动态类 动态属性)
- linux下C++开发常用工具
- PeopleSoft Rich Text Boxes上定制Tool Bars