专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像
专业版
轩辕镜像 官方专业版
轩辕镜像
专业版
首页个人中心搜索镜像

交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题轩辕镜像免费版
其他
关于我们网站地图
热门搜索:
ghcr.io/mellanox/nic-configuration-operator

ghcr.io/mellanox/nic-configuration-operator:v1.3.1

ghcr.iolinux/amd64v1.3.1大小: 未知更新于 2026年5月23日

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 配置

登录仓库拉取

通过 Docker 登录认证访问私有仓库

专属域名拉取

无需登录使用专属域名

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

Dev Containers

VS Code Dev Containers 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

Harbor 镜像源配置

Harbor Proxy Repository 对接专属域名

Portainer 镜像源配置

Portainer Registries 加速拉取

Nexus 镜像源配置

Nexus3 Docker Proxy 内网缓存

系统配置

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

MacOS OrbStack

MacOS OrbStack 容器配置

Docker Compose

Docker Compose 项目配置

NAS 设备

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

极空间

极空间 NAS 系统配置服务

网络设备

爱快路由

爱快 iKuai 路由系统配置

宝塔面板

在宝塔面板一键配置镜像

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

镜像拉取常见问题

使用与功能问题

配置了专属域名后,docker search 为什么会报错?

docker search 限制

Docker Hub 上有的镜像,为什么在轩辕镜像网站搜不到?

站内搜不到镜像

机器不能直连外网时,怎么用 docker save / load 迁镜像?

离线 save/load

docker pull 拉插件报错(plugin v1+json)怎么办?

插件要用 plugin install

WSL 里 Docker 拉镜像特别慢,怎么排查和优化?

WSL 拉取慢

轩辕镜像安全吗?如何用 digest 校验镜像没被篡改?

安全与 digest

第一次用轩辕镜像拉 Docker 镜像,要怎么登录和配置?

新手拉取配置

轩辕镜像合规吗?轩辕镜像的合规是怎么做的?

镜像合规机制

轩辕镜像支持 docker push 上传本地镜像吗?

不支持 push

错误码与失败问题

docker pull 提示 manifest unknown 怎么办?

manifest unknown

docker pull 提示 no matching manifest 怎么办?

no matching manifest(架构)

镜像已拉取完成,却提示 invalid tar header 或 failed to register layer 怎么办?

invalid tar header(解压)

Docker pull 时 HTTPS / TLS 证书验证失败怎么办?

TLS 证书失败

Docker pull 时 DNS 解析超时或连不上仓库怎么办?

DNS 超时

docker 无法连接轩辕镜像域名怎么办?

域名连通性排查

Docker 拉取出现 410 Gone 怎么办?

410 Gone 排查

出现 402 或「流量用尽」提示怎么办?

402 与流量用尽

Docker 拉取提示 UNAUTHORIZED(401)怎么办?

401 认证失败

遇到 429 Too Many Requests(请求太频繁)怎么办?

429 限流

docker login 提示 Cannot autolaunch D-Bus,还算登录成功吗?

D-Bus 凭证提示

为什么会出现「单层超过 20GB」或 413,无法加速拉取?

413 与超大单层

账号 / 计费 / 权限

轩辕镜像免费版和专业版有什么区别?

免费版与专业版区别

轩辕镜像支持哪些 Docker 镜像仓库?

支持的镜像仓库

镜像拉取失败还会不会扣流量?

失败是否计费

麒麟 V10 / 统信 UOS 提示 KYSEC 权限不够怎么办?

KYSEC 拦截脚本

如何在轩辕镜像申请开具发票?

申请开票

怎么修改轩辕镜像的网站登录和仓库登录密码?

修改登录密码

如何注销轩辕镜像账户?要注意什么?

注销账户

配置与原理类

写了 registry-mirrors,为什么还是走官方或仍然报错?

mirrors 不生效

怎么用 docker tag 去掉镜像名里的轩辕域名前缀?

去掉域名前缀

如何拉取指定 CPU 架构的镜像(如 ARM64、AMD64)?

指定架构拉取

用轩辕镜像拉镜像时快时慢,常见原因有哪些?

拉取速度原因

为什么拉取镜像的 :latest 标签,拿到的往往不是「最新」镜像?

latest 与「最新」

查看全部问题→

用户好评

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

用户头像

oldzhang

运维工程师

Linux服务器

5

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

轩辕镜像
镜像详情
...
ghcr.io/mellanox/nic-configuration-operator
博客Docker 镜像公告与技术博客
热门查看热门 Docker 镜像推荐
安装一键安装 Docker 并配置镜像源
镜像拉取问题咨询请 提交工单。官方公众号:源码跳动。官方技术交流群:51517718。轩辕镜像所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
镜像拉取问题咨询请提交工单。官方公众号:源码跳动。官方技术交流群:。轩辕镜像所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
商务合作:点击复制邮箱
©2024-2026 源码跳动
商务合作:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.