milvus-logo
LFAI
Home
  • Guía de administración
    • Escala

Dependencias de Scale Milvus

Milvus depende de varios componentes como MinIO, Kafka, Pulsar y etcd. Escalar estos componentes puede mejorar la adaptabilidad de Milvus a diferentes requisitos.

Escalar MinIO

Aumente los recursos por pod MinIO

MinIO, un sistema de almacenamiento de objetos utilizado por Milvus, puede aumentar sus recursos de CPU y memoria para cada pod.

# new-values.yaml
minio:
  resources:
     limits:
       cpu: 2
       memory: 8Gi

Después de guardar el archivo, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus

También puede aumentar la capacidad de disco para el cluster MioIO cambiando manualmente el valor de spec.resources.requests.storage para cada MioIO Persistent Volume Claim (PVC). Tenga en cuenta que su clase de almacenamiento predeterminada debe permitir la ampliación del volumen.

Se recomienda añadir un grupo de servidores MioIO adicional para su instancia de Milvus.

# new-values.yam;
minio:
  zones: 2

Después de guardar el archivo, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus

Esto añade un grupo de servidores adicional a su cluster MinIO, permitiendo a Milvus escribir en el grupo de servidores MinIO basándose en la capacidad de disco libre de cada grupo de servidores. Por ejemplo, si un grupo de tres pools tiene un total de 10 TiB de espacio libre distribuido entre los pools de la siguiente manera:

Espacio librePosibilidad de escritura
Grupo A3 TiB30% (3/10)
Grupo B2 TiB20% (2/10)
Grupo C5 TiB50% (5/10)

MinIO no reequilibra automáticamente los objetos en los nuevos grupos de servidores. Si es necesario, puede iniciar manualmente un procedimiento de reequilibrio con mc admin rebalance.

Kafka

Aumento de recursos por pod de broker de Kafka

Aumente la capacidad del broker Kafka ajustando los recursos de CPU y memoria para cada pod de broker.

# new-values.yaml
kafka:
  resources:
     limits:
        cpu: 2
        memory: 12Gi

Después de guardar el archivo, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus

También puede aumentar la capacidad de disco para el clúster de Kafka cambiando manualmente el valor de spec.resources.requests.storage para cada reclamación de volumen persistente (PVC) de Kafka. Asegúrese de que su clase de almacenamiento predeterminada permite la ampliación del volumen.

Se recomienda añadir un grupo de servidores Kafka adicional para su instancia de Milvus.

# new-values.yaml
kafka:
  replicaCount: 4

Después de guardar el archivo, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus

Esto añadirá un broker extra a su cluster de Kafka.

Kafka no reequilibra automáticamente los temas entre todos los corredores. Reequilibre manualmente los temas/particiones entre todos los corredores de Kafka utilizando bin/kafka-reassign-partitions.sh después de iniciar sesión en cada pod de corredor de Kafka si es necesario.

Pulsar

Pulsar separa la computación y el almacenamiento. Puede aumentar de forma independiente la capacidad de los corredores Pulsar (computación) y de los corredores Pulsar (almacenamiento).

Aumentar recursos por pod de broker Pulsar

# new-values.yaml
pulsar:
  broker:
    resources:
       limits:
         cpu: 4
         memory: 16Gi

Tras guardar el fichero, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus

Aumentar recursos por pod de corredor Pulsar

# new-values.yaml
pulsar:
  bookkeeper:
    resources:
       limits:
         cpu: 4
         memory: 16Gi

Después de guardar el fichero, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus

También puede aumentar la capacidad de disco para el clúster Pulsar cambiando manualmente el valor de spec.resources.requests.storage para cada reclamo de volumen persistente (PVC) del corredor Pulsar. Tenga en cuenta que su clase de almacenamiento predeterminada debe permitir la ampliación del volumen.

Un pod Pulsar bookie tiene dos tipos de almacenamiento: journal y legers. Para el tipo de almacenamiento journal, considere utilizar ssd o gp3 como clase de almacenamiento. A continuación se muestra un ejemplo para especificar storageclass para el diario Pulsar.

pulsar:
  bookkeeper:
    volumes:
      journal:
        size: 20Gi
        storageClassName: gp3

Añadir un pod de agente Pulsar adicional

# new-values.yaml
pulsar:
  broker:
    replicaCount: 3

Después de guardar el archivo, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus
# new-values.yaml
pulsar:
  bookkeeper:
    replicaCount: 3

Después de guardar el archivo, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus

etcd

# new-values.yaml
etcd:
  resources:
     limits:
       cpu: 2
       memory: 8Gi

Después de guardar el archivo, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus

Añadir pods etcd adicionales

El número total de pods etcd debe ser impar.

# new-values.yaml
etcd:
  replicaCount: 5

Después de guardar el archivo, aplique los cambios con el siguiente comando:

helm upgrade <milvus-release> --reuse-values -f new-values.yaml milvus/milvus