# increase TCP maximum buffer size
net.core.rmem_max = 16777216
net.core.wmem_max = 16777216
# increase Linux autotuning TCP buffer limits
# min, default, and maximum number of bytes to use
net.ipv4.tcp_rmem = 4096 87380 16777216
net.ipv4.tcp_wmem = 4096 65536 16777216
楼主的问题很模糊,我只能根据我的理解解答了。
楼主用什么语言?我默认是C的话,如下:
TCP发送不需要你太多关心,只要调用send(),操作系统的TCP实现会保证把你的数据发出去(网络畅通)。
收的时候可能需要recv()多次,因为TCP也不能保证发出去的包会一次都到达。需要加一个while()循环来保证收到全部的数据。
你指的BUFFER大小是什么?是TCP协议的BUFFER大小么?我默认是的,那这个BUFFER的大小是有操作系统默认的,一般是64KB, 当然也可以有程序设定的。操作系统还会有一个最大BUFFER的设置,默认可能是256KB, 也可能比这个大。如果为了优化TCP,你可以这样设置你的最大BUFFER大小:
比如,你的带宽是100Mbps, RTT是150ms, 则需要至少1.875M的最大BUFFER。如果是Linux的话,你可以在
/etc/sysctl.conf
文件里这样设置:保存后执行
sysctl -p
即可。(上面的数字是我瞎写的哦,不要当真,后果自负)如果你指的BUFFER是你的程序里数据大小的话,你在发送时不需要关心,TCP会根据实际情况把你的大数据分组发送的。(当然,如果你的带宽足够,且MAX BUFFER SIZE设置也合理地足够大,可能会把你的大数据一次发出去也说不定呢)。