Sobes.tech
Back to questions
Junior — Middle
62

Каким образом обеспечить запуск двух реплик контейнера так, чтобы они не размещались на одной рабочей ноде?

Companies where asked
Idaproject

Answer from AI

sobes.tech AI

Чтобы запустить две реплики контейнера так, чтобы они не размещались на одной рабочей ноде, в Kubernetes можно использовать аннотации или спецификации, обеспечивающие распределение подов по разным нодам.

Один из способов — использовать podAntiAffinity в манифесте Deployment или StatefulSet. Пример:

spec:
  replicas: 2
  template:
    spec:
      affinity:
        podAntiAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
          - labelSelector:
              matchExpressions:
              - key: app
                operator: In
                values:
                - my-app
            topologyKey: "kubernetes.io/hostname"

Это гарантирует, что поды с меткой app: my-app не будут размещены на одной и той же ноде (узле) по ключу kubernetes.io/hostname.

Если речь не о Kubernetes, а о другом оркестраторе, принцип схож: нужно настроить правила распределения или ограничения на размещение, чтобы реплики не попадали на одну машину.