在应用程序级别调整 TCP 数据包大小以实现最大吞吐量
TCP packet sizing at application level for max throughput
在应用程序级别,比如说使用 java,我需要担心多少实际的 TCP 数据包大小?因此,例如,我正在尝试编写一个应该通过TCP套接字的输出流发送数据的应用程序,我是否必须始终考虑写入流的数据的大小?由于 java 套接字是流式套接字,我实际上并没有考虑数据单元的大小,但是 OS/NIC 的 TSO(TCP 分段卸载(已"打开",然后我可以将 64KB 的数据切片或 MSS 写入输出流,从而尝试节省将数据切片到小于 1500 字节 (
我需要担心多少实际的 TCP 数据包大小?
几乎从不。 你可以设置NoTcpDelay(true(;但这很少有什么不同。
因此,例如,我正在尝试编写一个应该通过TCP套接字的输出流发送数据的应用程序,我是否必须始终考虑写入流的数据的大小?
我怀疑。 如果您的连接速度为 1 Gb 或更慢,您将无法编写效率低下的程序,以至于无法使用此带宽。
由于 java 套接字是流式套接字,我实际上并没有考虑数据单元的大小,但是 OS/NIC 的 TSO(TCP 分段卸载(被"打开",那么我可以将 64KB 的数据切片或 MSS 写入输出流,从而尝试节省将数据切片到小于 1500 字节 (
我不明白如何提供最体面的网络适配器支持 TCP 卸载。
就能够动态地处理这个问题而言,我的编程效果如何?
在任何情况下,Java都不支持它。
我知道我们可以让NetworkInterface.getMTU((来确定OS/NIC MTU的大小,但不确定它如何帮助。
我也没有。
所以,我可以说,总的来说,我对如何最大化对输出流的字节写入吞吐量有点困惑。
在Java中可以做出的最重要的改变是使用NIO。 我建议阻止蔚来汽车,因为这是蔚来汽车最简单的变化。 如果使用直接 ByteBuffers,则可以将冗余内存副本从 Java 保存到本机内存。
您是否知道在使用网络的最大带宽时遇到问题? 如果您尚未测量这是问题的原因,那只是一个猜测。
TCP 缓冲区、步调、决定段大小等幕后为您服务。除了尽可能快地写入,并在发送方使用大型套接字发送缓冲区,在接收方使用大型套接字接收缓冲区外,您无能为力。
- 如果没有malloc,链表实现将失败
- 如何在c++中实现处理器调度模拟器
- 如何在c++中使用引用实现类似python的行为
- 实现无开销push_back的最佳方法是什么
- 使用简单类型列表实现的指数编译时间.为什么
- 如何在BST的这个简单递归实现中消除警告
- 实现一个在集合上迭代的模板函数
- 我应该实现右值推送功能吗?我应该使用std::move吗
- 如何正确实现和访问运算符的各种自定义枚举器
- C++Union/Struct位域的实现和可移植性
- 这个极客对极客的trie实现是否存在内存泄漏问题
- 在c++中实现LinkedList时,应出现未处理的错误
- 为左值和右值的包装器实现C++范围
- 使用模板进行堆栈实现; "name followed by :: must be a class or namespace"
- 使用GSoap实现ONVIF
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 用于AVX的ln(x)的实现,m256
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用Ivy Bridge和Haswell展开环路以实现最大吞吐量
- 在应用程序级别调整 TCP 数据包大小以实现最大吞吐量