测量并提高千兆位以太网吞吐量

时间:2014-12-18 05:50:52

标签: c linux tcp

我们正在开发基于Cyclone V的定制板。它是运行嵌入式Linux内核3.10-ltsi的FPGA + ARM Soc。我们的预期应用是通过TCP千兆位以太网将大量原始大数据驻留在内存中,范围为50-400MB,发送到运行在Windows 7上的Java客户端。 iperf表明我们的主板的TCP吞吐量在6xxMBit / s的范围内。 问题: 1.我们有一个要求,我们需要在一定的时间间隔内发送原始内存数据。那么衡量我们案例吞吐量的正确方法是什么?目前我们只是用gettimeofday包装发送代码,如下所示:

int total_sent = 0, bytes_sent = 0;
gettimeofday(&t0, 0);
for (total_sent = 0; total_sent < data_size;) {
    bytes_sent = write(conn_fd, buf + total_sent, data_size - total_sent);
    if (bytes_sent == -1)
        break;
    total_sent += bytes_sent;
}
gettimeofday(&t1, 0);

unsigned long elapsed_us = (t1.tv_sec - t0.tv_sec) * 1000000 + t1.tv_usec - t0.tv_usec;
double elapsed_s = (double)elapsed_us / 1000000;
printf("Throughput: %f Mbit/s\n", img_size * 8 / elapsed_s / 1000000);
printf("Total bytes sent: %d\n", total_sent);

这是衡量吞吐量的正确方法吗?

2.是否可以通过两个以太网端口增加吞吐量?像将原始数据分成两部分并通过两个端口发送的东西。

3.在我们的案例中增加吞吐量的最佳方法是什么?我们希望达到的最大吞吐量是1024MBit / s。

1 个答案:

答案 0 :(得分:0)

  1. 一些评论:gettimeofday()系统调用的开销会影响您的测量结果。

  2. 确保以太网端口驱动程序已启用NAPI。

  3. 如果您想要最大吞吐量,请尝试获得零拷贝。如果您坚持使用TCP,也许您可​​以使用vmsplice()执行某些操作(请参阅:vmsplice() and TCP)。

  4. 为了获得最佳结果,请转储TCP,使用带有PACKET_MMAP选项(http://blog.superpat.com/2010/06/01/zero-copy-in-linux-with-sendfile-and-splice/)的数据包套接字并实现可靠的UDP协议(例如https://bitsecant.googlecode.com/svn-history/r8/trunk/src/net/rudp/ReliableServerSocket.java用于Win 7对等体的JAVA实现)。

  5. 祝你好运