九游平台/ 云容器引擎 cce/ / / / kubeflow部署
更新时间:2024-05-29 gmt 08:00

kubeflow部署-九游平台

kubeflow的诞生背景

基于kubernetes构建一个端到端的ai计算平台是非常复杂和繁琐的过程,它需要处理很多个环节。如图1所示,除了熟知的模型训练环节之外还包括数据收集、预处理、资源管理、特性提取、数据验证、模型的管理、模型发布、监控等环节。对于一个ai算法工程师来讲,如果要做模型训练,就不得不搭建一套ai计算平台,这个过程耗时费力,而且需要很多的知识积累。

图1 模型训练环节

kubeflow诞生于2017年,kubeflow项目是基于容器和kubernetes构建,旨在为数据科学家、机器学习工程师、系统运维人员提供面向机器学习业务的敏捷部署、开发、训练、发布和管理平台。它利用了云原生技术的优势,让用户更快速、方便的部署、使用和管理当前最流行的机器学习软件。

目前kubeflow 1.0版本已经发布,包含开发、构建、训练、部署四个环节,可全面支持企业用户的机器学习、深度学习完整使用过程。

如下图所示:

通过kubeflow 1.0,用户可以使用jupyter开发模型,然后使用fairing(sdk)等工具构建容器,并创建kubernetes资源训练其模型。模型训练完成后,用户还可以使用kfserving创建和部署用于推理的服务器。再结合pipeline(流水线)功能可实现端到端机器学习系统的自动化敏捷构建,实现ai领域的devops。

前提条件

  • 已在cce创建一个集群clustera,集群下有一个可用gpu节点,节点上的gpu卡数量大于等于2。

    由于安装kubeflow需要从github下载文件,从gcr.io等下载镜像,建议在华为云国际站创建集群,否则容易碰到较多网络问题。

  • 节点上绑定了eip,并配置了kubectl命令行工具,详情请参见。

安装kustomize

是一个开源工具,用于管理kubernetes应用程序的配置。它允许您将应用程序的配置从应用程序本身中分离出来,并根据需要进行修改。从kubeflow 1.3开始,所有组件都应仅使用kustomize进行部署。

  1. 安装kustomize。由于kubeflow与kustomize的早期版本不兼容,仅支持kustomize 5及更高版本,本文中使用5.1.0版本。
    curl -o install_kustomize.sh "https://raw.githubusercontent.com/kubernetes-sigs/kustomize/master/hack/install_kustomize.sh"
    sh install_kustomize.sh 5.1.0 .
    安装过程可能需要等待3-5分钟,回显如下:
    v5.1.0
    kustomize installed to /root/kubeflow/./kustomize
  2. 将kustomize移到/bin目录,以便在全局使用kustomize命令。
    cp kustomize /bin/

安装kubeflow

您可以参考以下步骤安装所有kubeflow官方组件。成功安装所有内容后,您可以访问kubeflow中央仪表板,详情请参见。

  1. 安装kubeflow 1.7.0版本。
    wget https://github.com/kubeflow/manifests/archive/refs/tags/v1.7.0.zip
    unzip v1.7.0.zip
  2. 使用kustomize创建用于部署kubeflow的yaml文件。
    cd ./manifests-1.7.0/
    kustomize build example -o example.yaml
  3. 配置kubeflow所需存储资源。
    • katib-mysql
    • mysql-pv-claim
    • minio-pv-claim
    • authservice-pvc

    由于kubeflow在创建时需要配置一些存储资源,官方示例中的存储配置无法在cce中生效,导致上述pvc无法创建。因此需要在集群中提前创建同名的pvc,本文中均以云硬盘类型为例,您可以按需替换云存储类型。

    创建pvc.yaml文件,yaml示例如下。

    apiversion: v1
    kind: persistentvolumeclaim
    metadata:
      name: katib-mysql
      namespace: kubeflow
      annotations:
        everest.io/disk-volume-type: sas    # 云硬盘的类型
      labels:
        failure-domain.beta.kubernetes.io/region:    # 替换为您待部署应用的节点所在的区域
        failure-domain.beta.kubernetes.io/zone:        # 替换为您待部署应用的节点所在的可用区
    spec:
      accessmodes:
        - readwriteonce
      resources:
        requests:
          storage: 10gi
      storageclassname: csi-disk
    ---
    apiversion: v1
    kind: persistentvolumeclaim
    metadata:
      name: mysql-pv-claim
      namespace: kubeflow
      annotations:
        everest.io/disk-volume-type: sas    # 云硬盘的类型
      labels:
        failure-domain.beta.kubernetes.io/region:    # 替换为您待部署应用的节点所在的区域
        failure-domain.beta.kubernetes.io/zone:        # 替换为您待部署应用的节点所在的可用区
    spec:
      accessmodes:
        - readwriteonce
      resources:
        requests:
          storage: 20gi
      storageclassname: csi-disk
    ---
    apiversion: v1
    kind: persistentvolumeclaim
    metadata:
      name: minio-pvc
      namespace: kubeflow
      annotations:
        everest.io/disk-volume-type: sas    # 云硬盘的类型
      labels:
        failure-domain.beta.kubernetes.io/region:    # 替换为您待部署应用的节点所在的区域
        failure-domain.beta.kubernetes.io/zone:        # 替换为您待部署应用的节点所在的可用区
    spec:
      accessmodes:
        - readwriteonce
      resources:
        requests:
          storage: 20gi
      storageclassname: csi-disk
    ---
    apiversion: v1
    kind: persistentvolumeclaim
    metadata:
      name: authservice-pvc
      namespace: istio-system
      annotations:
        everest.io/disk-volume-type: sas    # 云硬盘的类型
      labels:
        failure-domain.beta.kubernetes.io/region:    # 替换为您待部署应用的节点所在的区域
        failure-domain.beta.kubernetes.io/zone:        # 替换为您待部署应用的节点所在的可用区
    spec:
      accessmodes:
        - readwriteonce
      resources:
        requests:
          storage: 10gi
      storageclassname: csi-disk

    创建pvc。

    kubectl apply -f pvc.yaml 
  4. 创建kubeflow相关资源。
    kubectl apply -f example.yaml 

    由于网络原因,官方镜像可能无法拉取,导致工作负载出现imagepullbackoff或failedpullimage错误,请您自行添加合适的镜像代理。

  5. 查看所有命名空间下的pod是否都处于运行状态。
    kubectl get pod -a

    如果创建资源时出现非预期问题,请参见常见问题进行处理。

常见问题

  • 遇到一些crd资源不存在的场景,报错如下:
    error: resource mapping not found for name: "" namespace: "" from "stdin": no matches for kind "" in version ""
    ensure crds are installed first

    九游平台的解决方案

    这是因为kustomization创建crd和cr速度较快,可能会出现crd尚未创建就创建cr的情况。如果您遇到此错误,建议您重新创建资源。

  • 工作负载创建时,遇到节点pod过多的错误,报错如下:
    0/x nodes are available: x too many pods.

    九游平台的解决方案

    该错误说明节点上调度的pod超过节点最大实例数,建议扩容节点数。

  • training-operator负载不能正常运行,日志中报的错误如下:
    waited for 1.039518449s due to client-side throttling, not priority and fairness, request: get:https://10.247.0.1:443/apis/xxx/xx?timeout=32s

    九游平台的解决方案

    需要排除集群中不可用的apiservice,执行以下命令查看集群中的apiservice状态:

    kubectl get apiservice

    如果没有false状态的apiservice,等一到两分钟training-operator负载会正常运行。

相关文档

网站地图