0

0

【实测】基于Corundum架构的100G RDMA网卡

看不見的法師

看不見的法師

发布时间:2025-04-26 13:24:36

|

632人浏览过

|

来源于php中文网

原创

【实测】基于corundum架构的100g rdma网卡传统的tcp/ip技术在处理数据包时需要通过操作系统及其他软件层,导致数据在系统内存、处理器缓存和网络控制器缓存之间频繁复制,增加了服务器cpu和内存的负担,尤其是在网络带宽、处理器速度与内存带宽不匹配时,网络延迟会进一步加剧。rdma技术通过将数据处理从cpu旁路并卸载到硬件来实现低时延和高带宽特性。

基于这一研究背景,介绍一种具备RDMA功能的FPGA网卡实现方案—RNIC。本方案以Corundum开源高性能原型平台为基础,实现了100Gbps的RoCE v2网络协议栈卸载加速;在保留Corundum原生PCIe DMA引擎等组件的基础上,通过精准的拆分设计、逻辑耦合和路径复用,将RoCE v2网络协议栈嵌入到以太网网卡设计中。方案支持单边RDMA READ和RDMA WRITE操作、双边SEND/RECV操作以及立即数操作,提供Back-to-N的重传机制保障数据传输完整性的同时提供了可达256的Outstanding能力,并支持基于DCQCN算法的拥塞控制机制为本方案在数据中心等场景的大规模部署提供保障。实测RNIC能够实现低至4us左右的硬件端到端延迟以及高达96Gbps的吞吐量。

【实测】基于Corundum架构的100G RDMA网卡【实测】基于Corundum架构的100G RDMA网卡我们实现的100G RDMA网卡具体指标和性能如下:

【实测】基于Corundum架构的100G RDMA网卡【实测】基于Corundum架构的100G RDMA网卡测试场景及拓扑连接图如下。

【实测】基于Corundum架构的100G RDMA网卡【实测】基于Corundum架构的100G RDMA网卡TCP测试结果如下。

【实测】基于Corundum架构的100G RDMA网卡TCP性能表现:在Linux系统环境下,端到端连接拓扑,当MTU=9214B且未进行多核优化时,本方案的iperf TCP带宽可达59.7G bps;CPU占用率约为12%;TCP/IP协议的延迟普遍在100–200微秒之间。

TCP测试分析:性能开销主要集中在内核协议栈的系统调用、内存拷贝、协议处理及中断处理等方面。这些开销占用了大量的CPU资源,增加了数据延迟。

RDMA测试结果如下。

MallWWI新模式返利商城系统
MallWWI新模式返利商城系统

MallWWI新模式返利商城系统基于成熟的飞蛙商城系统程序框架,支持多数据库配合,精美的界面模板,人性化的操作体验,完备的订单流程,丰富的促销形式,适合搭建稳定、高效的电子商务平台。创造性的完美整合B2B\B2C\B2S\C2B\C2C\P2C\O2O\M2C\B2F等模式,引领“互联网+”理念,实现商家联盟体系下的线上线下全新整合销售方式,独创最流行的分红权返利与排队返钱卡功能。安全、稳定、结构

下载

【实测】基于Corundum架构的100G RDMA网卡【实测】基于Corundum架构的100G RDMA网卡RDMA性能表现:在Linux系统环境下,相同测试拓扑,使用配套驱动程序和应用程序发送RDMA命令进行测试。本方案的RDMA网卡实测单边RDMA语义读写带宽可达96.28G bps;CPU占用率不超过0.3%;硬件端到端读写延迟低至约4us。

RDMA测试分析:当消息大小大于8KB时,系统吞吐量可以接近满带宽,而当消息较小时,吞吐量会显著下降。原因一方面是数据帧帧头开销占比上升导致有效带宽下降,另一方面在于硬件设计无法支撑更高的消息速率。时延会随消息大小出现近似线性的增长,最大的延迟花费在PCIe链路和网络链路上,硬件的处理开销占比很小。

通过比较以太网和RDMA的测试结果可以看出,在相同的硬件条件下,使用RDMA技术的网卡可以拥有更高的网络带宽和更低的传输时延。对于云服务、数据中心等具有高吞吐量需求的网络业务场景,RDMA技术更能满足实际需求,能够充分解放处理器资源,提高带宽,降低成本。

【实测】基于Corundum架构的100G RDMA网卡以下视频详细介绍实际测试情况:https://www.php.cn/link/2cfd73d6effa33badc4c55b0c67a056d?

未来我们有许多工作要做,如添加我们之前做的P4可编程的工作(【Verilog开源】一种用于智能网卡或可编程交换机的,支持P4语言的高性能开源解析器的设计),突破Corundum架构限制支持百万QP对和提升小包性能,进一步优化流量控制、拥塞管理和负载均衡等问题,以进一步提高数据中心网络的数据传输速率和稳定性。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

386

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

569

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

398

2023.08.14

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1924

2024.08.16

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1347

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

700

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

80

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 8.4万人学习

Rust 教程
Rust 教程

共28课时 | 4.3万人学习

Vue 教程
Vue 教程

共42课时 | 6.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号