将工作负载集群部署到专用硬件

Tanzu Kubernetes Grid 支持在 vSphere 7.0 及更高版本上将工作负载集群部署到特定类型的启用了 GPU 的主机。

部署启用了 GPU 的工作负载集群

要在 vSphere 工作负载集群中使用具有 GPU 的节点,必须启用 PCI 直通模式。这允许集群绕过 ESXi 主管直接访问 GPU,从而提供与本机系统上 GPU 类似的性能级别。使用 PCI 直通模式时,每个 GPU 设备都专用于 vSphere 工作负载集群中的虚拟机 (VM)。

注意

要将启用了 GPU 的节点添加到现有集群,请使用 tanzu cluster node-pool set 命令。

必备条件

过程

要创建启用了 GPU 的主机的工作负载集群,请执行以下步骤以启用 PCI 直通、构建自定义计算机映像、创建集群配置文件和 Tanzu Kubernetes 版本、部署工作负载集群,以及使用 Helm 安装 GPU Operator。

  1. 将具有 GPU 卡的 ESXi 主机添加到 vSphere Client。

  2. 启用 PCI 直通并记录 GPU ID,如下所示:

    1. 在 vSphere Client,选择 GPU 集群中的目标 ESXi 主机。
    2. 选择配置 (Configure) > 硬件 (Hardware) > PCI 设备 (PCI Devices)
    3. 选择所有 PCI 设备 (All PCI Devices) 选项卡。
    4. 从列表中选择目标 GPU。
    5. 单击切换直通 (Toggle Passthrough)
    6. 在常规信息 (General Information) 下,记录设备 ID (Device ID) 和供应商 ID (Vendor ID)(在下图中以绿色突出显示)。相同的 GPU 卡的 ID 相同。对于集群配置文件,您将需要这些。

    显示 PCI 设备列表的 vSphere Client 接口。在列表下方,设备 ID 和供应商 ID 的位置用绿色框突出显示。

  3. 使用工作负载集群模板中的模板创建工作负载集群配置文件并包含以下变量:

    ...
    VSPHERE_WORKER_PCI_DEVICES: "0x<VENDOR-ID>:0x<DEVICE-ID>"
    VSPHERE_WORKER_CUSTOM_VMX_KEYS: 'pciPassthru.allowP2P=true,pciPassthru.RelaxACSforP2P=true,pciPassthru.use64bitMMIO=true,pciPassthru.64bitMMIOSizeGB=<GPU-SIZE>'
    VSPHERE_IGNORE_PCI_DEVICES_ALLOW_LIST: "<BOOLEAN>"
    VSPHERE_WORKER_HARDWARE_VERSION: vmx-17
    WORKER_ROLLOUT_STRATEGY: "RollingUpdate"
    

    其中:

    注意

    每个虚拟机只能使用一种类型的 GPU。例如,不能在单个虚拟机上同时使用 NVIDIA V100 和 NVIDIA Tesla T4,但可以使用具有相同供应商 ID 和设备 ID 的多个 GPU 实例。

    tanzu CLI 不允许更新 MachineDeployment 上的 WORKER_ROLLOUT_STRATEGY 规范。如果集群升级由于 PCI 设备不可用而停滞,VMware 建议使用 kubectl CLI 编辑 MachineDeployment 策略。部署策略在 spec.strategy.type 中定义。

    有关可以为启用了 GPU 的集群配置的变量的完整列表,请参见《配置文件变量参考》中的启用了 GPU 的集群

  4. 通过运行以下命令创建工作负载集群:

    tanzu cluster create -f CLUSTER-CONFIG-NAME
    

    其中 CLUSTER-CONFIG-NAME 是在前面的步骤中创建的集群配置文件的名称。

  5. 添加 NVIDIA Helm 存储库。

    helm repo add nvidia https://helm.ngc.nvidia.com/nvidia \
    && helm repo update
    
  6. 安装 NVIDIA GPU Operator:

    helm install --kubeconfig=./KUBECONFIG  --wait --generate-name -n gpu-operator --create-namespace nvidia/gpu-operator
    

    其中,KUBECONFIG 是工作负载集群的 kubeconfig 的名称和位置。有关详细信息,请参见检索工作负载集群 kubeconfig

    有关此命令中的参数的信息,请参见 NVIDIA 文档中的安装 GPU Operator

  7. 确保 NVIDIA GPU Operator 正在运行:

    kubectl --kubeconfig=./KUBECONFIG  get pods -A
    

    输出类似于:

    NAMESPACE         NAME                                                              READY   STATUS     RESTARTS   AGE
    gpu-operator      gpu-feature-discovery-szzkr                                       1/1     Running     0         6m18s
    gpu-operator      gpu-operator-1676396573-node-feature-discovery-master-7795vgdnd   1/1     Running     0         7m7s
    gpu-operator      gpu-operator-1676396573-node-feature-discovery-worker-bq6ct       1/1     Running     0         7m7s
    gpu-operator      gpu-operator-84dfbbfd8-jd98f                                      1/1     Running     0         7m7s
    gpu-operator      nvidia-container-toolkit-daemonset-6zncv                          1/1     Running     0         6m18s
    gpu-operator      nvidia-cuda-validator-2rz4m                                       0/1     Completed   0         98s
    gpu-operator      nvidia-dcgm-exporter-vgw7p                                        1/1     Running     0         6m18s
    gpu-operator      nvidia-device-plugin-daemonset-mln6z                              1/1     Running     0         6m18s
    gpu-operator      nvidia-device-plugin-validator-sczdk                              0/1     Completed   0         22s
    gpu-operator      nvidia-driver-daemonset-b7flb                                     1/1     Running     0         6m38s
    gpu-operator      nvidia-operator-validator-2v8zk                                   1/1     Running     0         6m18s
    

测试 GPU 集群

要测试启用了 GPU 的集群,请为 Kubernetes 文档中的 cuda-vector-add 示例创建 Pod 清单并进行部署。容器将下载、运行并使用 GPU 执行 CUDA 计算。

  1. 创建一个名为 cuda-vector-add.yaml 的文件并添加以下内容:

    apiVersion: v1
    kind: Pod
    metadata:
     name: cuda-vector-add
    spec:
     restartPolicy: OnFailure
     containers:
       - name: cuda-vector-add
         # https://github.com/kubernetes/kubernetes/blob/v1.7.11/test/images/nvidia-cuda/Dockerfile
         image: "registry.k8s.io/cuda-vector-add:v0.1"
         resources:
           limits:
             nvidia.com/gpu: 1 # requesting 1 GPU
    
  2. 应用文件:

    kubectl apply -f cuda-vector-add.yaml
    
  3. 运行:

    kubectl get po cuda-vector-add
    

    输出类似于:

    cuda-vector-add   0/1     Completed   0          91s
    
  4. 运行:

    kubectl logs cuda-vector-add
    

    输出类似于:

    [Vector addition of 50000 elements]
    Copy input data from the host memory to the CUDA device
    CUDA kernel launch with 196 blocks of 256 threads
    Copy output data from the CUDA device to the host memory
    Test PASSED
    Done
    

将工作负载集群部署到 Edge 站点

Tanzu Kubernetes Grid v1.6+ 支持将工作负载集群部署到 Edge VMware ESXi 主机。如果希望在不同的位置运行多个 Kubernetes 集群,这些集群全部由中央管理集群管理,则可以使用此方法。

拓扑:您可以在具有单个控制平面节点且仅具有一个或两个主机的生产环境中运行边缘工作负载集群。但是,尽管这使用较少的 CPU、内存和网络带宽,但您不具备标准生产 Tanzu Kubernetes Grid 集群的弹性和恢复特性。有关更多信息,请参见 VMware Tanzu 边缘解决方案参考架构 1.0

本地注册表:要最大程度地减少通信延迟并最大限度地提高弹性,每个边缘集群应具有自己的本地 Harbor 容器注册表。有关此架构的概述,请参见《架构概览》中的容器注册表。要安装本地 Harbor 注册表,请参见在 vSphere 上部署脱机 Harbor 注册表

超时:此外,当边缘工作负载集群在主数据中心具有远程管理集群时,您可能需要调整特定的超时,以使管理集群有足够的时间与工作负载集群计算机连接。要调整这些超时,请参见下面的扩展边缘集群超时以处理较高的延迟

延长边缘集群的超时以处理更高的延迟

如果您的管理集群远程管理在边缘站点上运行的工作负载集群或管理超过 20 个工作负载集群,则可以调整特定的超时,以便集群 API 不会阻止或删除可能暂时脱机或需要超过 12 分钟才能与其远程管理集群通信的计算机,尤其是在基础架构置备不足时。

您可以调整三个设置,为您的边缘集群提供额外的时间与其控制平面进行通信:

  • MHC_FALSE_STATUS_TIMEOUT:例如,将默认的 12m 扩展到 40m,以防止 MachineHealthCheck 控制器在其 Ready 状态保持为 False 超过 12 分钟时重新创建计算机。有关计算机运行状况检查的详细信息,请参见配置 Tanzu Kubernetes 集群的计算机运行状况检查

  • NODE_STARTUP_TIMEOUT:例如,将默认 20m 扩展到 60m,以防止 MachineHealthCheck 控制器阻止新计算机加入集群,因为新计算机启动时间超过 20 分钟,其会认为该操作不正常。

  • etcd-dial-timeout-duration:例如,在 capi-kubeadm-control-plane-controller-manager 中将默认的 10m 延长到 40s,以防止管理集群上的 etcd 客户端在扫描工作负载集群上 etcd 的运行状况时过早失败。管理集群使用其与 etcd 连接的能力作为计算机运行状况的衡量标准。例如:

    1. 在终端中,运行:

      kubectl edit  capi-kubeadm-control-plane-controller-manager -n capi-system
      
      
    2. 更改 --etcd-dial-timeout-duration 的值:

      - args:
           - --leader-elect
           - --metrics-bind-addr=localhost:8080
           - --feature-gates=ClusterTopology=false
           - --etcd-dial-timeout-duration=40s
           command:
           - /manager
           image: projects.registry.vmware.com/tkg/cluster-api/kubeadm-control-plane-controller:v1.0.1_vmware.1
      

此外,您需要注意:

  • capi-kubedm-control-plane-manager:如果它以某种方式与工作负载集群“分离”,您可能需要将其退回到新节点,以便它可以正确监控工作负载集群中的 etcd

  • TKG 中的 Pinniped 配置均假定工作负载集群已连接到管理集群。如果断开连接,您应该确保工作负载 Pod 使用管理帐户或服务帐户与边缘站点上的 API 服务器进行通信。否则,从管理集群断开连接将干扰边缘站点通过 Pinniped 对其本地工作负载 API 服务器进行身份验证的能力。

check-circle-line exclamation-circle-line close-line
Scroll to top icon