轩辕镜像 官方专业版
轩辕镜像
专业版
轩辕镜像 官方专业版
轩辕镜像
专业版
首页个人中心搜索镜像
交易
充值流量¥7起我的订单
文档
工具
提交工单页面收录
ghcr.io/mellanox/nic-configuration-operator

ghcr.io/mellanox/nic-configuration-operator:v0.1.13

ghcr.iolinux/amd64v0.1.13大小: 25.19 MB更新于 2026年6月21日
让 AI 帮你使用轩辕镜像? · 展开查看说明 · 点击收起说明

如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。

只需在 AI 对话中先发送下面这句话即可:

请先完整阅读并严格遵守以下文档中的全部规则与要求:

https://xuanyuan.cloud/agents.md

在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。

查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。

NVIDIA NIC Configuration Operator

NVIDIA NIC Configuration Operator 提供 Kubernetes API(自定义资源定义),以协调方式对 NVIDIA NIC 进行固件配置。它在每个目标节点上部署配置守护进程,以在这些节点上配置 NVIDIA NIC。NVIDIA NIC Configuration Operator 使用 Maintenance Operator 在实际配置前准备节点以进行维护。

部署

前提条件

  • Kubernetes 集群
  • 已部署 NVIDIA Network Operator。建议部署 DOCA-OFED 驱动程序
  • 已部署 Maintenance Operator

NVIDIA NIC Configuration Operator 可作为 NIC Cluster Policy CRD 的一部分部署。

自定义资源定义(CRD)

NICConfigurationTemplate

NICConfigurationTemplate CRD 用于为部分设备请求固件配置。

NIC Configuration Operator 将选择集群中与模板选择器匹配的 NIC 设备,并对其应用配置规格。

如果多个模板匹配同一设备,则不会应用任何模板,并且所有模板的状态中都会报告错误。

有关更多信息,请参阅 api-reference。

NICConfigurationTemplate 示例:

apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicConfigurationTemplate
metadata:
name: connectx6-config
namespace: network-operator
spec:
nodeSelector:
feature.node.kubernetes.io/network-sriov.capable: "true"
nicSelector:
# nicType 选择器为必填项,其余为可选项。只能指定单一类型。
nicType: 101b
pciAddresses:
- "0000:03:00.0"
- “0000:04:00.0”
serialNumbers:
- "MT2116X09299"
partNumbers:
- "MCX713106AEHEA_QP1"
resetToDefault: false # 若设置为 true,则忽略模板,设备配置将重置
template:
numVfs: 2
linkType: Ethernet
pciPerformanceOptimized:
enabled: true
maxAccOutRead: 44
maxReadRequest: 4096
roceOptimized:
enabled: true
qos:
trust: dscp
pfc: "0,0,0,1,0,0,0,0"
tos: 0
gpuDirectOptimized:
enabled: true
env: Baremetal

配置详情

  • numVFs:如果提供,将通过 nvconfig 配置 SR-IOV VF。这是必选参数。例如:若 numVFs=2,则 SRIOV_EN=1 且 SRIOV_NUM_OF_VFS=2;若 numVFs=0,则 SRIOV_EN=0 且 SRIOV_NUM_OF_VFS=0。 numVFs

    • 这是必选参数。
    • 例如:若 numVFs=2,则 SRIOV_EN=1 且 SRIOV_NUM_OF_VFS=2。 numVFs=2 SRIOV_EN=1 SRIOV_NUM_OF_VFS=2
    • 若 numVFs=0,则 SRIOV_EN=0 且 SRIOV_NUM_OF_VFS=0。 numVFs=0 SRIOV_EN=0 SRIOV_NUM_OF_VFS=0
  • linkType:如果提供,将为所有 NIC 端口配置 NIC 的链路类型。这是必选参数。例如,若 linkType = Infiniband,则设置 LINK_TYPE_P1=IB;若存在第二个 PCI 功能,则同时设置 LINK_TYPE_P2=IB。 linkType

    • 这是必选参数。
    • 例如,若 linkType = Infiniband,则设置 LINK_TYPE_P1=IB;若存在第二个 PCI 功能,则同时设置 LINK_TYPE_P2=IB。 linkType = Infiniband LINK_TYPE_P1=IB LINK_TYPE_P2=IB
  • pciPerformanceOptimized:执行 PCI 性能优化。若启用,默认将执行以下操作:

    • 设置 nvconfig 参数 MAX_ACC_OUT_READ 为 0(使用设备默认值) MAX_ACC_OUT_READ
    • 将每个 PF 的 PCI 最大读请求大小设置为 4096(注意:这是运行时配置,不持久化) 4096
    • 用户可通过 maxAccOutRead 和 maxReadRequest 覆盖值 maxAccOutRead maxReadRequest

[!IMPORTANT] 根据 PRM,将 MAX_ACC_OUT_READ 设置为 0 会启用自动模式,应用最合适的优化。但在某些 FW 版本中存在缺陷,导致无法使用 0 值。在此情况下,在修复可用前,MAX_ACC_OUT_READ 将不被设置,并会为该设备的 CR 发出警告事件。

  • 根据 PRM,将 MAX_ACC_OUT_READ 设置为 0 会启用自动模式,应用最合适的优化。但在某些 FW 版本中存在缺陷,导致无法使用 0 值。 MAX_ACC_OUT_READ

  • 在此情况下,在修复可用前,MAX_ACC_OUT_READ 将不被设置,并会为该设备的 CR 发出警告事件。 MAX_ACC_OUT_READ

  • roceOptimized:执行 RoCE 相关优化。若启用,默认执行以下操作:

    • 为两个端口设置 Nvconfig(可从 PF0 应用);若存在第二个端口,则有条件地应用于第二个端口
      • ROCE_CC_PRIO_MASK_P1=255,ROCE_CC_PRIO_MASK_P2=255 ROCE_CC_PRIO_MASK_P1=255 ROCE_CC_PRIO_MASK_P2=255
      • CNP_DSCP_P1=4,CNP_DSCP_P2=4 CNP_DSCP_P1=4 CNP_DSCP_P2=4
      • CNP_802P_PRIO_P1=6,CNP_802P_PRIO_P2=6 CNP_802P_PRIO_P1=6 CNP_802P_PRIO_P2=6
    • 为优先级 3 配置 pfc(优先级流控),在每个 PF 上设置信任模式为 dscp,将 ToS(服务类型)设置为 0。非持久化(需在每次启动后应用)
    • 用户可通过 trust、pfc 和 tos 参数覆盖值 trust pfc tos
    • 仅当 linkType=Ethernet 时可启用 linkType=Ethernet
  • gpuDirectOptimized:执行 GPU Direct 优化。目前仅支持裸机环境的优化。若启用,执行以下操作:

    • 设置 nvconfig ATS_ENABLED=0 ATS_ENABLED=0
    • 仅当 pciPerformanceOptimized 启用时才可启用 pciPerformanceOptimized
    • NVConfig 支持数值及其字符串别名(例如 REAL_TIME_CLOCK_ENABLE=False、REAL_TIME_CLOCK_ENABLE=0)。 REAL_TIME_CLOCK_ENABLE=False REAL_TIME_CLOCK_ENABLE=0
    • 对于每端口参数(后缀 _P1、_P2),若设备为单端口,则忽略带 _P2 后缀的参数。 _P1 _P2 _P2
  • spectrumXOptimized:启用 Spectrum-X 特定 NIC 优化。启用时:

    • 要求 linkType=Ethernet 且 numVfs=1 linkType=Ethernet numVfs=1
    • 不能与 roceOptimized 组合使用(RoCE 设置会自动包含) roceOptimized
    • 可与 rawNvConfig 组合使用——原始参数将作为覆盖项合并到 Spectrum-X 计算参数之上 rawNvConfig
    • 仅支持 ConnectX-8(nicType: 1023)、ConnectX-9(nicType: 1025)和 BlueField-3 SuperNIC(nicType: a2dc) nicType: 1023 nicType: 1025 nicType: a2dc
    • version:必选。参考架构版本(RA1.3、RA2.0、RA2.1 或 RA2.2) version RA1.3 RA2.0 RA2.1 RA2.2
    • overlay:可选,默认值为 none。设置为 l3 以启用 L3 E*** 覆盖网络 overlay none l3
    • multiplaneMode:可选,默认值为 none。仅在 RA2.1 中可用。选项:none、swplb、hwplb、uniplane multiplaneMode none none swplb hwplb uniplane
    • numberOfPlanes:可选,默认值为 1。仅在 RA2.1 中可用。选项:1、2 或 4

NIC Configuration Operator 支持针对不同版本 NVIDIA Spectrum-X 参考架构(RA1.3、RA2.0 和 RA2.1)的 Spectrum-X 特定 NIC 配置。

Spectrum-X 支持的 NIC 类型:

  • ConnectX-8(设备 ID 1023)——支持所有多平面模式
    1023- ConnectX-9(设备 ID 1025)——支持所有多平面模式(与 ConnectX-8 配置相同)
    1025- BlueField-3 SuperNIC(设备 ID a2dc)——支持除 hwplb 外的所有多平面模式
    a2dc``hwplbRA2.1 引入了多平面模式支持,允许 NIC 配置多个数据平面。可用模式:
模式描述支持的 NIC平面数
none单平面(默认)ConnectX-8、ConnectX-9、BF3 SuperNIC1
swplb软件数据包负载均衡ConnectX-8、ConnectX-9、BF3 SuperNIC2、4
hwplb硬件数据包负载均衡仅 ConnectX-8、ConnectX-92、4
uniplane单平面模式ConnectX-8、ConnectX-9、BF3 SuperNIC2

[!NOTE] 多平面模式仅在 RA2.1 中可用。对于 RA1.3 和 RA2.0,multiplaneMode 必须设为 none,numberOfPlanes 必须设为 1。

multiplaneMode``none``numberOfPlanes## 带多平面的 Spectrum-X NicConfigurationTemplate 示例

apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicConfigurationTemplate
metadata:
name: spectrum-x-multiplane-configuration
namespace: nvidia-network-operator
spec:
nodeSelector:
feature.node.kubernetes.io/network-sriov.capable: "true"
nicSelector:
nicType: "1023" # ConnectX-8。ConnectX-9 请使用 "1025",BlueField-3 SuperNIC 请使用 "a2dc"(BF3 不支持 hwplb)
# partNumbers:
# - "MCX713106AEHEA_QP1"
template:
numVfs: 1
linkType: Ethernet
spectrumXOptimized:
enabled: true
version: "RA2.1"
overlay: "none"
multiplaneMode: "hwplb" # 硬件数据包负载均衡,仅 ConnectX-8 支持
numberOfPlanes: 4

NicFirmwareSource

NICFirmwareSource CR 表示 NIC 固件二进制档案的 URL 源列表。

为 NIC 固件升级配置存储类

要启用 NIC 固件升级功能,NIC 集群策略中应提供 NicFirmwareStorage 部分。可选择创建新的 PVC 或使用现有 PVC。固件二进制文件将由供应器控制器供应,该控制器会监控 NICFirmwareSource 对象,并在由指定存储类启用的共享卷中供应二进制文件。节点代理需要确保引用的 NICFirmwareSource 对象已完全 reconciliation(status.state == Success),然后再进行固件更新。

NicFirmwareStorage## 存储类部署示例

要在集群中设置持久 NFS 存储,可使用 CSI NFS Driver 仓库中的示例。部署 NFS 服务器和 NFS CSI 驱动后,应部署存储类。然后可将存储类名称传递给 NIC 集群策略。

NICFirmwareSource 示例

# 请先修改此模板,它仅提供配置示例
apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicFirmwareSource
metadata:
name: connectx-6dx-firmware-22-44-1036
namespace: network-operator
finalizers:
- configuration.net.nvidia.com/nic-configuration-operator
spec:
# 来自 mlnx 网站的固件二进制文件列表,如果是压缩包,需解压后再放置
binUrlSources:
- https://www.mellanox.com/downloads/firmware/fw-ConnectX6Dx-rel-22_44_1036-MCX623106AC-CDA_Ax-UEFI-14.37.14-FlexBoot-3.7.500.signed.bin.zip
bfbUrlSource: https://example.com/bluefield3-31.41.0.bfb
status:
state: Success
binaryVersions:
22.44.1036:
- mt_0000000436
bfbVersions:
a2dc: 34.41.0 # BF3 NIC 固件
a2d6: 25.21.0 # BF2 NIC 固件

NICFirmwareTemplate

NICFirmwareTemplate CRD 用于从引用的 NICFirmwareSource 为部分设备请求固件验证或更新。

NIC Configuration Operator 会选择集群中与模板选择器匹配的 NIC 设备,并对其应用配置规范。

如果多个模板匹配同一设备,则不会应用任何模板,且所有模板的状态中都会报告错误。

有关更多信息,请参阅 api-reference。

NICFirmwareTemplate 示例

apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicFirmwareTemplate
metadata:
name: connectx6dx-config
namespace: network-operator
spec:
nodeSelector:
kubernetes.io/hostname: cloud-dev-41
nicSelector:
nicType: "101d"
# partNumbers:
# - "MCX713106AEHEA_QP1"
template:
nicFirmwareSourceRef: connectx6dx-firmware-22-44-1036
updatePolicy: Update

NICDevice

NICDevice CRD 由配置守护进程自动创建,代表特定 K8s 节点上的特定 NVIDIA NIC。设备名称由节点名称、设备类型及其 PCI 设备地址(域:总线:设备,其中 : 和 . 替换为 -)组合而成。使用 PCI 设备地址确保唯一性,因为在共享闪存 VPD 镜像的嵌入式 NIC 系统(如 HGX B300)上,序列号不能保证唯一。

Domain:Bus:DeviceFirmwareUpdateInProgress 状态条件可用于跟踪特定设备上固件验证/更新的状态。如果固件更新过程中发生错误,将在此字段中反映。ConfigUpdateInProgress 状态条件可用于跟踪特定设备上固件配置更新的状态。如果固件配置更新过程中发生错误,将在此字段中反映。

FirmwareUpdateInProgress``ConfigUpdateInProgress有关更多信息,请参阅 api-reference。

NICDevice 示例

apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicDevice
metadata:
name: co-node-25-101b-0000-04-00
namespace: nic-configuration-operator
spec:
firmware:
nicFirmwareSourceRef: connectx6dx-firmware-22-44-1036
updatePolicy: Update
configuration:
template:
linkType: Ethernet
numVfs: 8
pciPerformanceOptimized:
enabled: true
status:
conditions:
- reason: DeviceFirmwareConfigMatch
type: FirmwareUpdateInProgress
status: "False"
message: Firmware matches the requested version
- reason: UpdateSuccessful
type: ConfigUpdateInProgress
status: "False"
firmwareVersion: 20.42.1000
node: co-node-25
partNumber: mcx632312a-hdat
ports:
- networkInterface: enp4s0f0np0
pci: "0000:04:00.0"
rdmaInterface: mlx5_0
- networkInterface: enp4s0f1np1
pci: "0000:04:00.1"
rdmaInterface: mlx5_1
psid: mt_0000000225
serialNumber: mt2232t13210
type: 101b

实现细节:

NICDevice CRD 由配置守护进程创建并进行 reconciliation。reconciliation 逻辑方案可在此处找到。

NicInterfaceNameTemplate

NicInterfaceNameTemplate CRD 允许为 Spectrum-X NIC 上的 RDMA 和网络设备接口定义自定义命名模式。这在需要可预测接口命名的多平面和多轨部署中非常有用。

操作员会将udev规则部署到主机,以根据指定的命名模板重命名网络和RDMA接口。

模板使用以下占位符构建设备名称:

  • %nic_id%:NIC在扁平化NIC列表中的索引
    %nic_id%
  • %plane_id%:特定NIC的平面索引
    %plane_id%
  • %rail_id%:给定NIC所属的rail索引
    %rail_id%

NicInterfaceNameTemplate示例:

apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicInterfaceNameTemplate
metadata:
  name: spectrum-x-interface-names
  namespace: nvidia-network-operator
spec:
  pfsPerNic: 2
  rdmaDevicePrefix: "rdma_%nic_id%_%plane_id%_%rail_id%"
  netDevicePrefix: "net_%nic_id%_%plane_id%_%rail_id%"
  railPciAddresses:
    - ["0000:1a:00.0", "0000:2a:00.0"]
    - ["0000:3a:00.0", "0000:4a:00.0"]

railPciAddresses字段定义PCI地址到rail的映射。第一维度是rail索引,第二维度是该rail中NIC的PCI地址列表。

railPciAddresses

生成的udev规则

操作员根据模板生成udev规则并将其写入主机。规则被写入两个单独的文件:

网络设备的生成udev规则示例(/etc/udev/rules.d/10-nic-net-interface-naming.rules):

/etc/udev/rules.d/10-nic-net-interface-naming.rules

# Auto-generated by nic-configuration-operator
# Do not edit manually

SUBSYSTEM=="net", ACTION=="add", KERNELS=="0000:1a:00.0", NAME="net_0_0_0"
SUBSYSTEM=="net", ACTION=="add", KERNELS=="0000:1a:00.1", NAME="net_0_1_0"
SUBSYSTEM=="net", ACTION=="add", KERNELS=="0000:3a:00.0", NAME="net_1_0_1"
SUBSYSTEM=="net", ACTION=="add", KERNELS=="0000:3a:00.1", NAME="net_1_1_1"

RDMA设备的生成udev规则示例(/etc/udev/rules.d/10-nic-rdma-interface-naming.rules):

/etc/udev/rules.d/10-nic-rdma-interface-naming.rules

# Auto-generated by nic-configuration-operator
# Do not edit manually

ACTION=="add", KERNELS=="0000:1a:00.0", SUBSYSTEM=="infiniband", RUN+="/usr/bin/rdma dev set %k name rdma_0_0_0"
ACTION=="add", KERNELS=="0000:1a:00.1", SUBSYSTEM=="infiniband", RUN+="/usr/bin/rdma dev set %k name rdma_0_1_0"
ACTION=="add", KERNELS=="0000:3a:00.0", SUBSYSTEM=="infiniband", RUN+="/usr/bin/rdma dev set %k name rdma_1_0_1"
ACTION=="add", KERNELS=="0000:3a:00.1", SUBSYSTEM=="infiniband", RUN+="/usr/bin/rdma dev set %k name rdma_1_1_1"

操作顺序

要将NIC配置操作员纳入网络配置工作流,可能需要强制执行严格的操作顺序。例如,SR-IOV网络配置守护进程pod应在NIC配置守护进程完成后启动。为了向依赖NIC配置的pod指示配置何时进行中,操作员会管理nvidia.com/operator.nic-configuration.wait标签,当请求的NIC配置成功应用时,该标签值为false;当NIC配置进行中时,该标签值为true。要使用此机制,工作流中的后续pod可以将nvidia.com/operator.nic-configuration.wait=false添加到其节点标签选择器中。这样,当NIC正在配置时,它们将自动从节点驱逐。

nvidia.com/operator.nic-configuration.wait
false
true
nvidia.com/operator.nic-configuration.wait=false

NIC配置守护进程本身依赖节点上存在network.nvidia.com/operator.mofed.wait=false标签,因为它需要DOCA-OFED驱动程序运行以支持某些配置。

network.nvidia.com/operator.mofed.wait=false

功能标志

功能标志可通过helm chart或NVIDIA Network Operator的NicClusterPolicy中的环境变量启用。支持的标志:

  • FW_RESET_AFTER_CONFIG_UPDATE=true:在重启前和更新非易失性配置后显式重置NIC固件。在热重启后配置更新未成功应用的DGX服务器上可能需要此标志。

Spectrum-X 配置

NIC Configuration Operator 支持针对不同版本 NVIDIA Spectrum-X 参考架构(RA1.3、RA2.0 和 RA2.1)的 Spectrum-X 特定 NIC 配置。

Spectrum-X 支持的 NIC 类型:

  • ConnectX-8(设备 ID 1023)——支持所有多平面模式
  • ConnectX-9(设备 ID 1025)——支持所有多平面模式(与 ConnectX-8 配置相同)
  • BlueField-3 SuperNIC(设备 ID a2dc)——支持除 hwplb 外的所有多平面模式

RA2.1 引入了多平面模式支持,允许将 NIC 配置为多个数据平面。可用模式:

模式描述支持的 NIC平面数
none单平面(默认)ConnectX-8、ConnectX-9、BF3 SuperNIC1
swplb软件数据包负载均衡ConnectX-8、ConnectX-9、BF3 SuperNIC2、4
hwplb硬件数据包负载均衡仅 ConnectX-8、ConnectX-92、4
uniplane单平面模式ConnectX-8、ConnectX-9、BF3 SuperNIC2

[!NOTE] 多平面模式仅在 RA2.1 中可用。对于 RA1.3 和 RA2.0,multiplaneMode 必须设为 none,numberOfPlanes 必须设为 1。

带多平面的 Spectrum-X NicConfigurationTemplate 示例:

apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicConfigurationTemplate
metadata:
name: spectrum-x-multiplane-configuration
namespace: nvidia-network-operator
spec:
nodeSelector:
feature.node.kubernetes.io/network-sriov.capable: "true"
nicSelector:
nicType: "1023" # ConnectX-8。ConnectX-9 使用 "1025",BlueField-3 SuperNIC 使用 "a2dc"(BF3 不支持 hwplb)
# partNumbers:
# - "MCX713106AEHEA_QP1"
template:
numVfs: 1
linkType: Ethernet
spectrumXOptimized:
enabled: true
version: "RA2.1"
overlay: "none"
multiplaneMode: "hwplb" # 硬件数据包负载均衡,仅 ConnectX-8 支持
numberOfPlanes: 4

NicFirmwareSource

NICFirmwareSource CR 表示包含 NIC FW 二进制文件归档的 URL 源列表。

为 NIC FW 升级配置存储类

要启用 NIC FW 升级功能,需在 https://github.com/Mellanox/network-operator/blob/7c31e789835afdad114b1a68011e5307bc773bcf/api/v1alpha1/nicclusterpolicy_types.go#L321 中提供 NicFirmwareStorage 部分。可以选择创建新的 PVC 或使用现有 PVC。 固件二进制文件将由供应器控制器进行供应,该控制器会监视 NICFirmwareSource 对象,并在由指定存储类启用的共享卷中供应二进制文件。 节点代理需要确保引用的 NICFirmwareSource 对象已完全协调(status.state == Success),然后才能进行固件更新。

存储类部署示例

要在集群中设置持久 NFS 存储,可使用 https://github.com/kubernetes-csi/csi-driver-nfs/blob/master/deploy/example/nfs-provisioner/README.md%E3%80%82 部署 NFS 服务器和 NFS CSI 驱动程序后,应部署 https://github.com/kubernetes-csi/csi-driver-nfs/blob/master/deploy/example/storageclass-nfs.yaml%E3%80%82%E7%84%B6%E5%90%8E%E5%8F%AF%E5%B0%86%E5%AD%98%E5%82%A8%E7%B1%BB%E7%9A%84%E5%90%8D%E7%A7%B0%E4%BC%A0%E9%80%92%E7%BB%99 NIC Cluster Policy。

NICFirmwareSource 示例:

NICFirmwareTemplate

NICFirmwareTemplate CRD 用于从引用的 NICFirmwareSource 为部分设备请求固件验证或更新。

NIC 配置操作员将选择集群中与模板选择器匹配的 NIC 设备,并对其应用配置规范。

如果多个模板匹配单个设备,则不会应用任何模板,并且所有模板的状态中都会报告错误。

有关更多信息,请参阅 API 参考。

NICFirmwareTemplate 示例:

apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicFirmwareTemplate
metadata:
name: connectx6dx-config
namespace: network-operator
spec:
nodeSelector:
kubernetes.io/hostname: cloud-dev-41
nicSelector:
nicType: "101d"
# partNumbers:
# - "MCX713106AEHEA_QP1"
template:
nicFirmwareSourceRef: connectx6dx-firmware-22-44-1036
updatePolicy: Update

NICDevice

NICDevice CRD 由配置守护进程自动创建,代表特定 K8s 节点上的特定 NVIDIA NIC。 设备名称组合了节点名称、设备类型及其 PCI 设备地址(Domain:Bus:Device,其中 : 和 . 替换为 -)。PCI 设备地址用于确保唯一性,因为在共享刷写 VPD 镜像的嵌入式 NIC 系统(例如 HGX B300)上,序列号不能保证唯一。

FirmwareUpdateInProgress 状态条件可用于跟踪特定设备上固件验证/更新的状态。如果固件更新过程中发生错误,将在此字段中反映。 ConfigUpdateInProgress 状态条件可用于跟踪特定设备上固件配置更新的状态。如果固件配置更新过程中发生错误,将在此字段中反映。

有关更多信息,请参阅 API 参考。

NICDevice 示例

apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicDevice
metadata:
name: co-node-25-101b-0000-04-00
namespace: nic-configuration-operator
spec:
firmware:
nicFirmwareSourceRef: connectx6dx-firmware-22-44-1036
updatePolicy: Update
configuration:
template:
linkType: Ethernet
numVfs: 8
pciPerformanceOptimized:
enabled: true
status:
conditions:
- reason: DeviceFirmwareConfigMatch
type: FirmwareUpdateInProgress
status: "False"
message: Firmware matches the requested version
- reason: UpdateSuccessful
type: ConfigUpdateInProgress
status: "False"
firmwareVersion: 20.42.1000
node: co-node-25
partNumber: mcx632312a-hdat
ports:
- networkInterface: enp4s0f0np0
pci: "0000:04:00.0"
rdmaInterface: mlx5_0
- networkInterface: enp4s0f1np1
pci: "0000:04:00.1"
rdmaInterface: mlx5_1
psid: mt_0000000225
serialNumber: mt2232t13210
type: 101b

实现细节:

NicDevice CRD 由配置守护进程创建并协调。协调逻辑图可在 此处 找到。

NicInterfaceNameTemplate

NicInterfaceNameTemplate CRD 允许您为 Spectrum-X NIC 上的 RDMA 和网络设备接口定义自定义命名模式。这在需要可预测接口命名的多平面和多导轨部署中非常有用。

操作员会将 udev 规则部署到主机,以根据指定的命名模板重命名网络和 RDMA 接口。

模板使用以下占位符构建设备名称:

  • %nic_id%: NIC 在扁平化 NIC 列表中的索引
  • %plane_id%: 特定 NIC 的平面索引
  • %rail_id%: 给定 NIC 所属的导轨索引

NicInterfaceNameTemplate 示例:

apiVersion: configuration.net.nvidia.com/v1alpha1
kind: NicInterfaceNameTemplate
metadata:
name: spectrum-x-interface-names
namespace: nvidia-network-operator
spec:
pfsPerNic: 2
rdmaDevicePrefix: "rdma_%nic_id%_%plane_id%_%rail_id%"
netDevicePrefix: "net_%nic_id%_%plane_id%_%rail_id%"
railPciAddresses:
- ["0000:1a:00.0", "0000:2a:00.0"]
- ["0000:3a:00.0", "0000:4a:00.0"]

railPciAddresses 字段定义 PCI 地址到导轨的映射。第一维是导轨索引,第二维是该导轨中 NIC 的 PCI 地址列表。

生成的 udev 规则

操作员根据模板生成 udev 规则并将其写入主机。规则写入两个单独的文件:

网络设备的生成 udev 规则示例(/etc/udev/rules.d/10-nic-net-interface-naming.rules):

# 由 nic-configuration-operator 自动生成
# 请勿手动编辑

SUBSYSTEM=="net", ACTION=="add", KERNELS=="0000:1a:00.0", NAME="net_0_0_0"
SUBSYSTEM=="net", ACTION=="add", KERNELS=="0000:1a:00.1", NAME="net_0_1_0"
SUBSYSTEM=="net", ACTION=="add", KERNELS=="0000:3a:00.0", NAME="net_1_0_1"
SUBSYSTEM=="net", ACTION=="add", KERNELS=="0000:3a:00.1", NAME="net_1_1_1"

RDMA 设备的生成 udev 规则示例(/etc/udev/rules.d/10-nic-rdma-interface-naming.rules):

# 由 nic-configuration-operator 自动生成
# 请勿手动编辑

ACTION=="add", KERNELS=="0000:1a:00.0", SUBSYSTEM=="infiniband", RUN+="/usr/bin/rdma dev set %k name rdma_0_0_0"
ACTION=="add", KERNELS=="0000:1a:00.1", SUBSYSTEM=="infiniband", RUN+="/usr/bin/rdma dev set %k name rdma_0_1_0"
ACTION=="add", KERNELS=="0000:3a:00.0", SUBSYSTEM=="infiniband", RUN+="/usr/bin/rdma dev set %k name rdma_1_0_1"
ACTION=="add", KERNELS=="0000:3a:00.1", SUBSYSTEM=="infiniband", RUN+="/usr/bin/rdma dev set %k name rdma_1_1_1"

操作顺序

轩辕镜像配置手册

按平台快速找到配置文档

一键安装

一键安装 Docker

Linux Docker 一键安装

AI

用 AI 使用轩辕镜像

agents.md · AI 对话 · 提示词

Docker

登录仓库拉取

登录认证 · 私有仓库

专属域名拉取

免登录 · 高速拉取

Linux

Docker 镜像配置

Windows / Mac

Docker Desktop 配置

MacOS OrbStack

OrbStack 容器

Apple Container

macOS 原生容器

Docker Compose

Compose 项目配置

NAS

群晖

Synology 配置

飞牛

fnOS 镜像配置

绿联

绿联 NAS

威联通

QNAP 配置

极空间

极空间 NAS

Unraid

Unraid NAS

企业仓库

其他仓库

ghcr · Quay · nvcr

Harbor 镜像源

Proxy Repository 对接

Portainer 镜像源

Registries 配置

Nexus 镜像源

Docker Proxy 缓存

开发工具

Dev Containers

VS Code 开发容器

Podman

Podman 配置指南

Singularity / Apptainer

HPC 科学计算容器

Kubernetes

K8s Containerd

Kubernetes · Containerd

K3s

轻量级集群

面板 / 网络

爱快路由

iKuai 镜像加速

宝塔面板

一键配置镜像源

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

功能

版本功能对比

功能对比 · 版本选择

支持的镜像仓库

Docker Hub · GCR · GHCR

新手拉取配置

登录 · 专属域名 · 配置

docker search 限制

专属域名 · Hub 搜索

不支持 push

仅支持 pull · 不支持

拉取速度原因

带宽 · 缓存 · 冷热镜像

错误码

402 与流量用尽

402 · 流量包 · 充值

401 认证失败

401 · docker login

manifest unknown

标签错误 · 镜像不存在

410 Gone 排查

410 · Docker 升级

429 限流

免费版 · 专业版 · 企业版 · 请求频率

其他报错

DNS 超时

DNS 解析 · 网络超时

TLS 证书失败

no matching manifest(架构)

账号

失败是否计费

manifest · blob · 计费

申请开发票(企业 / 个人)

企业 · 个人 · 工单

修改登录密码

网站 · 仓库 · 重置

注销账户

工单 · 数据 · 注销

原理

mirrors 不生效

daemon.json · 重启

去掉域名前缀

docker tag · 重命名

指定架构拉取

ARM64 · AMD64 · 多架构

latest 与「最新」

digest · 版本号 · 标签

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
ghcr.io/mellanox/nic-configuration-operator
教程轩辕镜像功能与使用教程
定价查看流量套餐与价格
热门查看热门 Docker 镜像推荐
博客Docker 镜像公告与技术博客
专业版 · 高速稳定拉取镜像
高速镜像下载·在线技术支持·99.95% SLA 保障·付费会员免广告
50GB 仅 ¥7/年
专业版 · 高速稳定拉取镜像
50GB 仅 ¥7/年
高速镜像下载·在线技术支持·99.95% SLA 保障·付费会员免广告
用户协议·隐私政策·增值电信业务经营许可证:浙B2-20261007·©2024-2026 源码跳动©2024-2026 杭州源码跳动科技有限公司·商务合作:点击复制邮箱