TCP连接的最大数据包大小是多少,或者如何获得最大数据包大小?
当前回答
在应用程序级别,应用程序使用TCP作为面向流的协议。TCP则具有段,并抽象了处理不可靠IP数据包的细节。
TCP处理的是段而不是包。每个TCP段都有一个序列号,序列号包含在TCP报头中。 TCP段中实际发送的数据是可变的。
getsockopt有一个在某些操作系统上支持的值,称为TCP_MAXSEG,用于检索最大TCP段大小(MSS)。但并非所有操作系统都支持它。
我不确定你到底想做什么,但如果你想减少缓冲区的大小,你也可以看看:SO_SNDBUF和SO_RCVBUF。
其他回答
通常,这取决于连接使用的接口。您可以使用ioctl()来获得MTU,如果是以太网,通常可以通过从硬件头的大小减去硬件头的大小来获得最大数据包大小,对于没有VLAN的以太网,硬件头的大小为14。
只有当整个网络的MTU至少有这么大时,才会出现这种情况。TCP可能使用路径MTU发现来减少有效MTU。
问题是,你为什么这么在乎?
IP协议(Ip4)中TCP设置的包大小。对于这个字段(TL),分配了16位,因此数据包的最大大小为65535字节:IP协议细节
一种解决方案是将套接字选项TCP_MAXSEG (http://linux.die.net/man/7/tcp)设置为一个对底层网络“安全”的值(例如,设置为1400在以太网上是安全的),然后在发送系统调用时使用一个大的缓冲区。 这样可以减少昂贵的系统调用。 内核将拆分数据以匹配MSS。
这样可以避免截断数据,应用程序也不必担心缓冲区太小。
似乎互联网上的大多数网站都使用1460字节作为MTU值。有时它是1452,如果你是在VPN上,它会为IPSec头降低更多。
默认窗口大小变化很大,最大可达65535字节。我使用http://tcpcheck.com查看我自己的源IP值,并检查其他互联网供应商正在使用什么。
TCP API中没有包。
底层协议中通常有一些数据包,比如TCP在IP上运行时,你对这些数据包不感兴趣,因为它们与用户没有任何关系,除了非常微妙的性能优化,你可能对这些性能优化不感兴趣(根据问题的提法)。
如果你问在一个API调用中可以发送()的最大字节数是多少,那么这取决于实现和设置。您通常会调用send()来获取最多几千字节的数据块,并随时准备好系统完全或部分拒绝接受它,在这种情况下,您必须手动管理将数据分割为更小的数据块,以便将数据送入TCP send() API。
推荐文章
- TCP连接的最大数据包大小
- HTTP 1.1和HTTP 2.0的区别是什么?
- connectexception:拒绝连接
- 互联网上最大的安全UDP包大小是多少
- 关闭vs关闭套接字?
- 如何解决“java.net.BindException: Address already in use: JVM_Bind”错误?
- 增加Linux中TCP/IP连接的最大数量
- 模拟慢速网络连接的网络工具
- Android检查网络连接
- 在Linux上模拟延迟和丢弃的包
- 现代Linux机顶盒理论上最大的TCP连接数是多少
- Linux上的网络使用top/htop
- 什么是P99延迟?
- 在Wireshark上捕获手机流量
- pty和tty是什么意思?