KubeVelaに基づく機械学習の実践

著者:KubeVelaコミュニティ

現在の機械学習の波では、AIエンジニアは自分のモデルをトレーニングしてデバッグするだけでなく、モデルの効果を検証するためにモデルをオンラインで展開する必要があります(もちろん、作業のこの部分はAIシステムエンジニア。)。作業のこの部分は退屈で、AIエンジニアにとって余分な労力を消費します。

クラウドネイティブの時代では、モデルのトレーニングとモデルの提供も通常はクラウドで実行されます。そうすることで、スケーラビリティが向上するだけでなく、リソース使用率も向上します。これは、大量のコンピューティングリソースを消費する機械学習シナリオに非常に効果的です。

しかし、AIエンジニアがクラウドネイティブ機能を使用することはしばしば困難です。クラウドネイティブの概念は、時間の経過とともにより複雑になっています。クラウドネイティブに単純なモデルサービスをデプロイするには、AIエンジニアは、デプロイメント、サービス、イングレスなど、いくつかの追加の概念を学ぶ必要がある場合があります。

シンプルで使いやすく、拡張性の高いクラウドネイティブアプリケーション管理ツールであるKubeVelaを使用すると、開発者は、基盤となるクラウドネイティブインフラストラクチャの詳細を知らなくても、Kubernetesでアプリケーションをすばやく簡単に定義して配信できます。KubeVelaは拡張性に優れています。AIプラグインは、モデルトレーニング、モデルサービス、A / Bテストなどの機能を提供し、AIエンジニアの基本的なニーズをカバーし、AIエンジニアがクラウドネイティブ環境でモデルトレーニングとモデルトレーニングを迅速に実施できるようにします。 。サーブ。

この記事では主に、KubeVelaのAIプラグインを使用して、エンジニアがモデルトレーニングとモデルサービスをより簡単に完了できるようにする方法を紹介します。

KubeVela AI 插件

KubeVela AIプラグインは、モデルトレーニングとモデルサービスの2つのプラグインに分かれています。モデルトレーニングプラグインは、TensorFlow、PyTorch、MXNetなどのさまざまなフレームワークの分散モデルトレーニングをサポートできるKubeFlowのトレーニングオペレーターに基づいています。 。モデルサービスプラグインはSeldonCoreに基づいており、モデルを使用してモデルサービスを簡単に開始でき、トラフィック分散やA/Bテストなどの高度な機能もサポートしています。

KubeVela AIプラグインを使用すると、モデルトレーニングタスクとモデルサービスの展開を大幅に簡素化できます。同時に、モデルトレーニングとモデルサービスのプロセスをKubeVela独自のワークフロー、マルチクラスター、その他の機能と組み合わせて、完全な本番環境で利用可能なサービス。デプロイします。

注:すべてのソースコードとYAMLファイルはKubeVelaサンプル[1]にあり  ます。この例で事前トレーニングされたモデルを使用する場合は、フォルダー内のstyle-model.yamlとcolor-model.yamlがモデルをPVCにコピーします。

モデルトレーニング

まず、モデルトレーニングとモデルサービング用の2つのプラグインを起動します。

vela addon enable model-training
vela addon enable model-serving
复制代码

モデルトレーニングには、モデルトレーニングとjupyter-notebookの2つのコンポーネントタイプが含まれ、モデルサービングにはモデルサービングが含まれます。これら3つのコンポーネントの特定のパラメーターは、velashowコマンドで表示できます。

詳細については、KubeVelaAIプラグインのドキュメント[2]を参照することもできます。

vela show model-training
vela show jupyter-notebook
vela show model-serving
复制代码

灰色の画像を色に変換するTensorFlowフレームワークを使用して、単純なモデルをトレーニングしましょう。次のYAMLファイルをデプロイします。

注:モデルトレーニングのソースコードは、emilwallner /Coloring-greyscale-images [3]から取得されます。

apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
  name: training-serving
  namespace: default
spec:
  components:
  # 训练模型
  - name: demo-training
    type: model-training
    properties:
      # 训练模型的镜像
      image: fogdong/train-color:v1
      # 模型训练的框架
      framework: tensorflow
      # 声明存储,将模型持久化。此处会使用集群内的默认 storage class 来创建 PVC
      storage:
        - name: "my-pvc"
          mountPath: "/model"
复制代码

この時点で、KubeVelaはモデルトレーニングのためにTFJobをプルアップします。

モデルをトレーニングしただけでは効果を確認するのは難しいので、このYAMLファイルを変更して、モデルトレーニングステップの後にモデルサービスを配置しましょう。同時に、モデルサービスはモデルを直接開始し、モデルの入力と出力は直感的ではないため(ndarrayまたはTensor)、サービスを呼び出して結果を画像に変換するテストサービスを展開します。

次のYAMLファイルをデプロイします。

apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
  name: training-serving
  namespace: default
spec:
  components:
  # 训练模型
  - name: demo-training
    type: model-training
    properties:
      image: fogdong/train-color:v1
      framework: tensorflow
      storage:
        - name: "my-pvc"
          mountPath: "/model"
  
  # 启动模型服务
  - name: demo-serving
    type: model-serving
    # 模型服务会在模型训练完成后启动
    dependsOn:
      - demo-training
    properties:
      # 启动模型服务使用的协议,可以不填,默认使用 seldon 自身的协议
      protocol: tensorflow
      predictors:
        - name: model
          # 模型服务的副本数
          replicas: 1
          graph:
            # 模型名
            name: my-model
            # 模型框架
            implementation: tensorflow
            # 模型地址,上一步会将训练完的模型保存到 my-pvc 这个 pvc 当中,所以通过 pvc://my-pvc 指定模型的地址
            modelUri: pvc://my-pvc

  # 测试模型服务
  - name: demo-rest-serving
    type: webservice
    # 测试服务会在模型训练完成后启动
    dependsOn:
      - demo-serving
    properties:
      image: fogdong/color-serving:v1
      # 使用 LoadBalancer 暴露对外地址,方便调用
      exposeType: LoadBalancer
      env:
        - name: URL
          # 模型服务的地址
          value: http://ambassador.vela-system.svc.cluster.local/seldon/default/demo-serving/v1/models/my-model:predict
      ports:
        # 测试服务的端口
        - port: 3333
          expose: true
复制代码

デプロイ後、バージョンを使用してアプリケーションのステータスを表示します。

$ vela ls

training-serving        demo-training        model-training           running  healthy  Job Succeeded  2022-03-02 17:26:40 +0800 CST
├─                    demo-serving         model-serving            running  healthy  Available      2022-03-02 17:26:40 +0800 CST
└─                    demo-rest-serving    webservice               running  healthy  Ready:1/1      2022-03-02 17:26:40 +0800 CST
复制代码

ご覧のとおり、アプリケーションは正常に起動しています。vela status --endpointを使用して、アプリケーションのサービスアドレスを表示します。

$ vela status training-serving --endpoint

+---------+-----------------------------------+---------------------------------------------------+
| CLUSTER |     REF(KIND/NAMESPACE/NAME)      |                     ENDPOINT                      |
+---------+-----------------------------------+---------------------------------------------------+
|         | Service/default/demo-rest-serving | tcp://47.251.10.177:3333                          |
|         | Service/vela-system/ambassador    | http://47.251.36.228/seldon/default/demo-serving  |
|         | Service/vela-system/ambassador    | https://47.251.36.228/seldon/default/demo-serving |
+---------+-----------------------------------+---------------------------------------------------+
复制代码

该应用有三个服务地址,第一个是我们的测试服务的地址,第二个和第三都是原生模型的地址。我们可以调用测试服务来查看模型的效果:测试服务会读取图像的内容,并将其转成 Tensor 并请求模型服务,最后将模型服务返回的 Tensor 转成图像返回。

我们选择一张黑白的女性图片作为输入:

请求后,可以看到,输出了一张彩色图片:

模型服务:灰度测试

除了直接启动模型服务,我们还可以在一个模型服务中使用多个版本的模型,并对其分配不同的流量以进行灰度测试。

部署如下 YAML,可以看到,v1 版本的模型和 v2 版本的模型都设置为了 50% 的流量。同样,我们在模型服务后面部署一个测试服务:

apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
  name: color-serving
  namespace: default
spec:
  components:
  - name: color-model-serving
    type: model-serving
    properties:
      protocol: tensorflow
      predictors:
        - name: model1
          replicas: 1
          # v1 版本的模型流量为 50
          traffic: 50
          graph:
            name: my-model
            implementation: tensorflow
            # 模型地址,在 color-model 这个 pvc 中 /model/v1 路径下存放了我们的 v1 版本模型,所以通过 pvc://color-model/model/v1 指定模型的地址
            modelUri: pvc://color-model/model/v1
        - name: model2
          replicas: 1
          # v2 版本的模型流量为 50
          traffic: 50
          graph:
            name: my-model
            implementation: tensorflow
            # 模型地址,在 color-model 这个 pvc 中 /model/v2 路径下存放了我们的 v2 版本模型,所以通过 pvc://color-model/model/v2 指定模型的地址
            modelUri: pvc://color-model/model/v2
  - name: color-rest-serving
    type: webservice
    dependsOn:
      - color-model-serving
    properties:
      image: fogdong/color-serving:v1
      exposeType: LoadBalancer
      env:
        - name: URL
          value: http://ambassador.vela-system.svc.cluster.local/seldon/default/color-model-serving/v1/models/my-model:predict
      ports:
        - port: 3333
          expose: true
复制代码

当模型部署完成后,通过 vela status --endpoint 查看模型服务的地址:

$ vela status color-serving --endpoint

+---------+------------------------------------+----------------------------------------------------------+
| CLUSTER |      REF(KIND/NAMESPACE/NAME)      |                         ENDPOINT                         |
+---------+------------------------------------+----------------------------------------------------------+
|         | Service/vela-system/ambassador     | http://47.251.36.228/seldon/default/color-model-serving  |
|         | Service/vela-system/ambassador     | https://47.251.36.228/seldon/default/color-model-serving |
|         | Service/default/color-rest-serving | tcp://47.89.194.94:3333                                  |
+---------+------------------------------------+----------------------------------------------------------+
复制代码

使用一张黑白的城市图片请求模型:

可以看到,第一次请求的结果如下。虽然天空和地面都被渲染成彩色了,但是城市本身还是黑白的:

再次请求,可以看到,这次请求的结果中,天空、地面和城市都被渲染成了彩色:

通过对不同版本的模型进行流量分发,可以帮助我们更好地对模型结果进行判断。

模型服务:A/B 测试

同样一张黑白的图片,我们既可以通过模型将其变成彩色的,也可以通过上传另一张风格图片,对原图进行风格迁移。

对于用户来说,究竟是彩色的图片好还是不同风格的图片更胜一筹?我们可以通过进行 A/B 测试,来探索这个问题。

部署如下 YAML,通过设置 customRouting,将 Header 中带有 style: transfer 的请求,转发到风格迁移的模型。同时,使这个风格迁移的模型与彩色化的模型共用一个地址。

注:风格迁移的模型来源于 TensorFlow Hub [4]

apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
  name: color-style-ab-serving
  namespace: default
spec:
  components:
  - name: color-ab-serving
    type: model-serving
    properties:
      protocol: tensorflow
      predictors:
        - name: model1
          replicas: 1
          graph:
            name: my-model
            implementation: tensorflow
            modelUri: pvc://color-model/model/v2
  - name: style-ab-serving
    type: model-serving
    properties:
      protocol: tensorflow
      # 风格迁移的模型需要的时间较长,设置超时时间使请求不会被超时
      timeout: "10000"
      customRouting:
        # 指定自定义 Header
        header: "style: transfer"
        # 指定自定义路由
        serviceName: "color-ab-serving"
      predictors:
        - name: model2
          replicas: 1
          graph:
            name: my-model
            implementation: tensorflow
            modelUri: pvc://style-model/model
  - name: ab-rest-serving
    type: webservice
    dependsOn:
      - color-ab-serving
      - style-ab-serving
    properties:
      image: fogdong/style-serving:v1
      exposeType: LoadBalancer
      env:
        - name: URL
          value: http://ambassador.vela-system.svc.cluster.local/seldon/default/color-ab-serving/v1/models/my-model:predict
      ports:
        - port: 3333
          expose: true
复制代码

部署成功后,通过 vela status --endpoint 查看模型服务的地址:

$ vela status color-style-ab-serving --endpoint

+---------+---------------------------------+-------------------------------------------------------+
| CLUSTER |    REF(KIND/NAMESPACE/NAME)     |                       ENDPOINT                        |
+---------+---------------------------------+-------------------------------------------------------+
|         | Service/vela-system/ambassador  | http://47.251.36.228/seldon/default/color-ab-serving  |
|         | Service/vela-system/ambassador  | https://47.251.36.228/seldon/default/color-ab-serving |
|         | Service/vela-system/ambassador  | http://47.251.36.228/seldon/default/style-ab-serving  |
|         | Service/vela-system/ambassador  | https://47.251.36.228/seldon/default/style-ab-serving |
|         | Service/default/ab-rest-serving | tcp://47.251.5.97:3333                                |
+---------+---------------------------------+-------------------------------------------------------+
复制代码

这个应用中,两个服务各自有两个地址,但是第二个 style-ab-serving 的模型服务地址是无效的,因为这个模型服务已经被指向了 color-ab-serving 的地址中。同样,我们通过请求测试服务来查看模型效果。

首先,在不加 header 的情况下,图像会从黑白变为彩色:

我们添加一个海浪的图片作为风格渲染:

我们为本次请求加上 style: transfer 的 Header,可以看到,城市变成了海浪风格:

我们还可以使用一张水墨画的图片作为风格渲染:

可以看到,这次城市变成了水墨画风格:

总结

通过 KubeVela 的 AI 插件,可以帮助你更便捷地进行模型训练与模型服务。

除此之外,通过与 KubeVela 的结合,我们还能将测试完效果的模型通过 KubeVela 的多环境功能,下发到不同的环境中,从而实现模型的灵活部署。

相关链接

[1] KubeVela Samples

​https://github.com/oam-dev/samples/tree/master/11.Machine_Learning_Demo​

[2] KubeVela AI 插件文档

​https://kubevela.io/zh/docs/next/reference/addons/ai​

[3] emilwallner/Coloring-greyscale-images

​https://github.com/emilwallner/Coloring-greyscale-images​

[4]TensorFlow Hub

​https://tfhub.dev/google/magenta/arbitrary-image-stylization-v1-256/2​

近期热门

您可以通过如下材料了解更多关于 KubeVela 以及 OAM 项目的细节:

  • 项目代码库:​github.com/oam-dev/kubevela​ 欢迎 Star/Watch/Fork!
  • 项目官方主页与文档:kubevela.io ,从 1.1 版本开始,已提供中文、英文文档,更多语言文档欢迎开发者进行翻译。
  • 项目钉钉群:23310022;Slack:CNCF #kubevela Channel
  • 加入微信群:请先添加以下 maintainer 微信号,表明进入 KubeVela 用户群:

点击“​此处​​”,查看 KubeVela 项目官网。​

おすすめ

転載: juejin.im/post/7082846935823941646