您的位置:首页 > 其它

各种流量采集方式的性能对比测试结果

2017-05-18 16:26 489 查看


各种流量采集方式的性能对比测试结果

    近期对“原始套接字+recvfrom”,“原始套接字+mmap”,“pcap”和零拷贝四种采集方式做了采集性能的对比测试。 

    测试环境如下:P4 Xeon 1.6G 双核,内存2G 

                            网卡流量为116MB/s,包数为30万个/s 

     测试程序使用单进程单线程,从开始采集以前和结束采集后计数,计算所消耗的时间。对包的处理方面,仅判断包的类型,统计个数和流量,无其他业务代码。 

    各种采集方式采集1000万个包所花费的时间为: 

方式     时间        平均CPU占用率 

=================================================== 

原始套接字+recvfrom        35.25s      60% 

原始套接字+mmap            34.95s       46% 

pcap                                 50.08s       100% 

零拷贝                              35.34s       0% 

     由于网卡上的流量根据实际情况在变化,因此“原始套接字+recvfrom”,“原始套接字+mmap”,“零拷贝”这三种方式消耗的时间可认为大致相同,不同在于CPU的占用率。PCAP的采集性能最低,如果不经过这次测试,我还一直以为PCAP是应用层采集方式中性能最高的呢! 

     测试说明: 

      1、LINUX对于网络流量的处理是比较优异的,底层的数据包会快速地送到应用层,从“原始套接字+recvfrom”,“原始套接字+mmap”,“零拷贝”这三种方式的采集时间大致相同就可以看出这一点。 
     2、对于高性能的数据采集,零拷贝始终是首选,如果空转的时候CPU都消耗得很高,则加上业务后根被没多少CPU资源可用了。

转自:http://blog.csdn.net/lionzl/article/details/7803324
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: