NVIDIA NIC Configuration Operator 提供 Kubernetes API(自定义资源定义),以协调方式对 NVIDIA NIC 进行固件配置。它在每个目标节点上部署配置守护进程,以在这些节点上配置 NVIDIA NIC。NVIDIA NIC Configuration Operator 使用 Maintenance Operator 在实际配置前准备节点以进行维护。
NVIDIA NIC Configuration Operator 可作为 NIC Cluster Policy CRD 的一部分部署。
NICConfigurationTemplate CRD 用于为部分设备请求固件配置。
NIC Configuration Operator 将选择集群中与模板选择器匹配的 NIC 设备,并对其应用配置规格。
如果多个模板匹配同一设备,则不会应用任何模板,并且所有模板的状态中都会报告错误。
有关更多信息,请参阅 api-reference。
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=2numVFs=0 SRIOV_EN=0 SRIOV_NUM_OF_VFS=0linkType:如果提供,将为所有 NIC 端口配置 NIC 的链路类型。这是必选参数。例如,若 linkType = Infiniband,则设置 LINK_TYPE_P1=IB;若存在第二个 PCI 功能,则同时设置 LINK_TYPE_P2=IB。
linkType
linkType = Infiniband LINK_TYPE_P1=IB LINK_TYPE_P2=IBpciPerformanceOptimized:执行 PCI 性能优化。若启用,默认将执行以下操作:
MAX_ACC_OUT_READ4096maxAccOutRead 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 相关优化。若启用,默认执行以下操作:
ROCE_CC_PRIO_MASK_P1=255 ROCE_CC_PRIO_MASK_P2=255CNP_DSCP_P1=4 CNP_DSCP_P2=4CNP_802P_PRIO_P1=6 CNP_802P_PRIO_P2=6trust pfc toslinkType=EthernetgpuDirectOptimized:执行 GPU Direct 优化。目前仅支持裸机环境的优化。若启用,执行以下操作:
ATS_ENABLED=0pciPerformanceOptimizedREAL_TIME_CLOCK_ENABLE=False REAL_TIME_CLOCK_ENABLE=0_P1 _P2 _P2spectrumXOptimized:启用 Spectrum-X 特定 NIC 优化。启用时:
linkType=Ethernet numVfs=1roceOptimizedrawNvConfignicType: 1023 nicType: 1025 nicType: a2dcversion RA1.3 RA2.0 RA2.1 RA2.2overlay none l3multiplaneMode none none swplb hwplb uniplaneSpectrum-X 支持的 NIC 类型:
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 SuperNIC | 1 |
swplb | 软件数据包负载均衡 | ConnectX-8、ConnectX-9、BF3 SuperNIC | 2、4 |
hwplb | 硬件数据包负载均衡 | 仅 ConnectX-8、ConnectX-9 | 2、4 |
uniplane | 单平面模式 | ConnectX-8、ConnectX-9、BF3 SuperNIC | 2 |
[!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 CR 表示 NIC 固件二进制档案的 URL 源列表。
要启用 NIC 固件升级功能,NIC 集群策略中应提供 NicFirmwareStorage 部分。可选择创建新的 PVC 或使用现有 PVC。固件二进制文件将由供应器控制器供应,该控制器会监控 NICFirmwareSource 对象,并在由指定存储类启用的共享卷中供应二进制文件。节点代理需要确保引用的 NICFirmwareSource 对象已完全 reconciliation(status.state == Success),然后再进行固件更新。
NicFirmwareStorage## 存储类部署示例
要在集群中设置持久 NFS 存储,可使用 CSI NFS Driver 仓库中的示例。部署 NFS 服务器和 NFS CSI 驱动后,应部署存储类。然后可将存储类名称传递给 NIC 集群策略。
# 请先修改此模板,它仅提供配置示例
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 CRD 用于从引用的 NICFirmwareSource 为部分设备请求固件验证或更新。
NIC Configuration Operator 会选择集群中与模板选择器匹配的 NIC 设备,并对其应用配置规范。
如果多个模板匹配同一设备,则不会应用任何模板,且所有模板的状态中都会报告错误。
有关更多信息,请参阅 api-reference。
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 CRD 由配置守护进程自动创建,代表特定 K8s 节点上的特定 NVIDIA NIC。设备名称由节点名称、设备类型及其 PCI 设备地址(域:总线:设备,其中 : 和 . 替换为 -)组合而成。使用 PCI 设备地址确保唯一性,因为在共享闪存 VPD 镜像的嵌入式 NIC 系统(如 HGX B300)上,序列号不能保证唯一。
Domain:Bus:DeviceFirmwareUpdateInProgress 状态条件可用于跟踪特定设备上固件验证/更新的状态。如果固件更新过程中发生错误,将在此字段中反映。ConfigUpdateInProgress 状态条件可用于跟踪特定设备上固件配置更新的状态。如果固件配置更新过程中发生错误,将在此字段中反映。
FirmwareUpdateInProgress``ConfigUpdateInProgress有关更多信息,请参阅 api-reference。
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 CRD 允许为 Spectrum-X NIC 上的 RDMA 和网络设备接口定义自定义命名模式。这在需要可预测接口命名的多平面和多轨部署中非常有用。
操作员会将udev规则部署到主机,以根据指定的命名模板重命名网络和RDMA接口。
模板使用以下占位符构建设备名称:
%nic_id%%plane_id%%rail_id%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规则示例(/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中的环境变量启用。支持的标志:
NIC Configuration Operator 支持针对不同版本 NVIDIA Spectrum-X 参考架构(RA1.3、RA2.0 和 RA2.1)的 Spectrum-X 特定 NIC 配置。
Spectrum-X 支持的 NIC 类型:
1023)——支持所有多平面模式1025)——支持所有多平面模式(与 ConnectX-8 配置相同)a2dc)——支持除 hwplb 外的所有多平面模式RA2.1 引入了多平面模式支持,允许将 NIC 配置为多个数据平面。可用模式:
| 模式 | 描述 | 支持的 NIC | 平面数 |
|---|---|---|---|
none | 单平面(默认) | ConnectX-8、ConnectX-9、BF3 SuperNIC | 1 |
swplb | 软件数据包负载均衡 | ConnectX-8、ConnectX-9、BF3 SuperNIC | 2、4 |
hwplb | 硬件数据包负载均衡 | 仅 ConnectX-8、ConnectX-9 | 2、4 |
uniplane | 单平面模式 | ConnectX-8、ConnectX-9、BF3 SuperNIC | 2 |
[!NOTE] 多平面模式仅在 RA2.1 中可用。对于 RA1.3 和 RA2.0,
multiplaneMode必须设为none,numberOfPlanes必须设为1。
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 CR 表示包含 NIC FW 二进制文件归档的 URL 源列表。
要启用 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。
NICFirmwareTemplate CRD 用于从引用的 NICFirmwareSource 为部分设备请求固件验证或更新。
NIC 配置操作员将选择集群中与模板选择器匹配的 NIC 设备,并对其应用配置规范。
如果多个模板匹配单个设备,则不会应用任何模板,并且所有模板的状态中都会报告错误。
有关更多信息,请参阅 API 参考。
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 CRD 由配置守护进程自动创建,代表特定 K8s 节点上的特定 NVIDIA NIC。
设备名称组合了节点名称、设备类型及其 PCI 设备地址(Domain:Bus:Device,其中 : 和 . 替换为 -)。PCI 设备地址用于确保唯一性,因为在共享刷写 VPD 镜像的嵌入式 NIC 系统(例如 HGX B300)上,序列号不能保证唯一。
FirmwareUpdateInProgress 状态条件可用于跟踪特定设备上固件验证/更新的状态。如果固件更新过程中发生错误,将在此字段中反映。
ConfigUpdateInProgress 状态条件可用于跟踪特定设备上固件配置更新的状态。如果固件配置更新过程中发生错误,将在此字段中反映。
有关更多信息,请参阅 API 参考。
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 CRD 允许您为 Spectrum-X NIC 上的 RDMA 和网络设备接口定义自定义命名模式。这在需要可预测接口命名的多平面和多导轨部署中非常有用。
操作员会将 udev 规则部署到主机,以根据指定的命名模板重命名网络和 RDMA 接口。
模板使用以下占位符构建设备名称:
%nic_id%: NIC 在扁平化 NIC 列表中的索引%plane_id%: 特定 NIC 的平面索引%rail_id%: 给定 NIC 所属的导轨索引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 规则示例(/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 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
不支持 push
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务