跳到主要内容

在 Kubernetes 上分配资源

本主题介绍了如何在 Kubernetes 上为 Milvus 集群分配资源。

通常情况下,您在生产环境中为 Milvus 集群分配的资源应该与机器工作量成比例。在分配资源时,您还应考虑机器类型。虽然您可以在集群运行时更新配置,但我们建议在部署集群之前设置这些值。

1. 查看可用资源

运行 kubectl describe nodes 命令查看您已经预配的实例上的可用资源。

2. 分配资源

使用 Helm 为 Milvus 组件分配 CPU 和内存资源。

使用 Helm 升级资源将导致正在运行的 Pod 执行滚动更新。

有两种分配资源的方式:

使用命令分配资源

如果您使用 --set 来更新资源配置,您需要为每个 Milvus 组件设置资源变量。

helm upgrade my-release milvus/milvus --reuse-values --set standalone.resources.limits.cpu=2 --set standalone.resources.limits.memory=4Gi --set standalone.resources.requests.cpu=0.1 --set standalone.resources.requests.memory=128Mi
helm upgrade my-release milvus/milvus --reuse-values --set dataNode.resources.limits.cpu=2 --set dataNode.resources.limits.memory=4Gi --set dataNode.resources.requests.cpu=0.1 --set dataNode.resources.requests.memory=128Mi

通过设置配置文件分配资源

您还可以通过在 resources.yaml 文件中指定参数 resources.requestsresources.limits 来分配 CPU 和内存资源。

dataNode:
resources:
limits:
cpu: "4"
memory: "16Gi"
requests:
cpu: "1"
memory: "4Gi"
queryNode:
resources:
limits:
cpu: "4"
memory: "16Gi"
requests:
cpu: "1"
memory: "4Gi"

3. 应用配置

运行以下命令将新配置应用到您的 Milvus 集群中。

helm upgrade my-release milvus/milvus --reuse-values -f resources.yaml

如果未指定resources.limits,Pod 将会消耗所有可用的 CPU 和内存资源。因此,请确保指定resources.requestsresources.limits,以避免在同一实例上运行其他任务需要更多内存时资源过度分配。

有关管理资源的更多信息,请参阅Kubernetes 文档

下一步