SPDK NVMe-oF RDMA连接问题分析与解决
问题现象描述
在使用SPDK搭建NVMe over Fabrics (NVMe-oF) RDMA环境时,用户遇到了连接失败的问题。具体表现为在主机端执行nvme discover命令时出现"Connection reset by peer"错误,同时内核日志中出现"kobject is not initialized"警告信息。
环境配置
- 硬件平台:基于飞腾FT5000c处理器的ARM64服务器
- 网络设备:Mellanox CX-6网卡(RDMA)
- 软件版本:
- SPDK版本:24.01
- 内核版本:6.6.0-11
- MLNX驱动版本:24.07-0.6.1.0
详细错误分析
初始错误表现
当尝试通过RDMA连接到NVMe-oF目标端时,主机端出现以下错误:
nvme discover -t rdma -a xx.xx.xx.51 -s 4421
Failed to write to /dev/nvme-fabrics: Connection reset by peer
failed to add controller, error failed to write to nvme-fabrics device
内核日志(dmesg)中同时出现以下警告:
[18328.544917] HG@\x07: rdma connection establishment failed (-104)
[18328.545049] kobject: '' (00000000b63ad2f9): is not initialized, yet kobject_put() is being called.
深入分析
-
RDMA连接失败:错误代码-104(ECONNRESET)表明连接被对等方重置,这通常意味着网络层面存在问题。
-
kobject警告:这是一个内核对象管理相关的警告,表明在释放资源时出现了异常情况,通常是由于资源初始化不完整或释放顺序不当导致的。
-
网络配置问题:进一步排查发现,服务器上同时存在以太网卡和RDMA网卡,且它们的IP地址配置在同一网段。这种配置可能导致路由混乱,影响RDMA通信。
解决方案
经过多次测试和分析,最终确定问题根源在于网络配置冲突。具体解决方案如下:
-
隔离网络配置:确保RDMA网卡和以太网卡的IP地址不在同一子网内。例如:
- 以太网卡使用192.168.1.x网段
- RDMA网卡使用172.16.1.x网段
-
临时验证方法:可以通过禁用以太网接口来快速验证问题:
ifconfig enp4s2f0 down -
永久解决方案:修改网络配置文件,确保不同网络接口使用不同的IP地址段,避免路由冲突。
技术原理深入
NVMe-oF RDMA通信机制
NVMe over RDMA是一种高性能存储网络协议,它利用RDMA(远程直接内存访问)技术实现低延迟、高吞吐量的存储访问。当出现连接问题时,需要从以下几个层面进行排查:
- 网络层面:检查IP可达性、子网划分、路由表等
- RDMA层面:验证RDMA设备状态、队列对(QP)配置等
- NVMe协议层面:确认控制器ID匹配、发现服务等
多网卡环境下的路由问题
在同时配置以太网和RDMA网卡的环境中,如果IP地址配置在同一子网,可能导致以下问题:
- 路由不确定性:系统可能选择错误的网络接口发送数据包
- ARP冲突:同一IP子网内的不同接口可能导致ARP表混乱
- RDMA通信中断:RDMA特有的CM(Connection Manager)可能无法正确建立连接
最佳实践建议
- 网络规划:为RDMA网络单独规划IP地址段,避免与其他网络冲突
- 配置检查:部署前使用
ip addr和ip route命令检查网络配置 - 隔离测试:先使用最简单的网络配置进行连通性测试,再逐步添加复杂配置
- 日志监控:密切关注系统日志和SPDK日志,及时发现潜在问题
总结
通过本次问题的排查和解决,我们了解到在部署SPDK NVMe-oF RDMA环境时,合理的网络规划至关重要。特别是在多网卡环境中,必须确保RDMA网络与其他网络的隔离性,避免IP地址冲突和路由混乱。这一经验对于构建高性能、高可靠的存储网络架构具有重要参考价值。
AutoGLM-Phone-9BAutoGLM-Phone-9B是基于AutoGLM构建的移动智能助手框架,依托多模态感知理解手机屏幕并执行自动化操作。Jinja00
Kimi-K2-ThinkingKimi K2 Thinking 是最新、性能最强的开源思维模型。从 Kimi K2 开始,我们将其打造为能够逐步推理并动态调用工具的思维智能体。通过显著提升多步推理深度,并在 200–300 次连续调用中保持稳定的工具使用能力,它在 Humanity's Last Exam (HLE)、BrowseComp 等基准测试中树立了新的技术标杆。同时,K2 Thinking 是原生 INT4 量化模型,具备 256k 上下文窗口,实现了推理延迟和 GPU 内存占用的无损降低。Python00
GLM-4.6V-FP8GLM-4.6V-FP8是GLM-V系列开源模型,支持128K上下文窗口,融合原生多模态函数调用能力,实现从视觉感知到执行的闭环。具备文档理解、图文生成、前端重构等功能,适用于云集群与本地部署,在同类参数规模中视觉理解性能领先。Jinja00
HunyuanOCRHunyuanOCR 是基于混元原生多模态架构打造的领先端到端 OCR 专家级视觉语言模型。它采用仅 10 亿参数的轻量化设计,在业界多项基准测试中取得了当前最佳性能。该模型不仅精通复杂多语言文档解析,还在文本检测与识别、开放域信息抽取、视频字幕提取及图片翻译等实际应用场景中表现卓越。00
GLM-ASR-Nano-2512GLM-ASR-Nano-2512 是一款稳健的开源语音识别模型,参数规模为 15 亿。该模型专为应对真实场景的复杂性而设计,在保持紧凑体量的同时,多项基准测试表现优于 OpenAI Whisper V3。Python00
GLM-TTSGLM-TTS 是一款基于大语言模型的高质量文本转语音(TTS)合成系统,支持零样本语音克隆和流式推理。该系统采用两阶段架构,结合了用于语音 token 生成的大语言模型(LLM)和用于波形合成的流匹配(Flow Matching)模型。 通过引入多奖励强化学习框架,GLM-TTS 显著提升了合成语音的表现力,相比传统 TTS 系统实现了更自然的情感控制。Python00
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00