繁体   English   中英

K8S pod 在不同节点上有两个副本

[英]K8S pods with two replicas on different nodes

我有两个副本的 pod,k8s 将同时重新安排两个副本是否有意义? 如果是,有没有办法避免它?

我猜(根据@Henry 的回复)我需要使用https://kube.netes.io/docs/concepts/scheduling-eviction/assign-pod-node/#affinity-and-anti-affinity

拓扑https://kube.netes.io/blog/2020/05/introducing-podtopologyspread/

但不确定如何配置以下内容:

1应用程序有2副本,例如

Replica AnodeFoo上运行,并且

Replica BNodeBar中运行

要将副本配置为在不同节点上运行,可以使用podAntiAffinity 例如在部署规范中:

spec:    
  template:
    metadata:
      labels:
        name: my-app-label
    spec:
      affinity:
        podAntiAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            - labelSelector:
                matchLabels:
                  name: my-app-label
              topologyKey: kubernetes.io/hostname

这基本上意味着,所有与 label name=my-app-label匹配的 pod 应该在节点 label kube.netes.io/hostname不同的主机上运行。

假设您的意思是部署,是的,Pod 对象是大致同时创建和调度的。 如果您希望按顺序创建事物,请使用 StatefulSet。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM