Kubernetes仅按特定标签在节点上运行特定部署

时间:2020-10-09 23:44:23

标签: kubernetes kubernetes-deployment

使用Kubernetes,我有一组高cpu的节点,并且我正在针对给定部署使用关联性策略来专门针对这些高cpu节点:

# deployment.yaml
spec:
  affinity:
    nodeAffinity:
      requiredDuringSchedulingIgnoredDuringExecution:
        nodeSelectorTerms:
        - matchExpressions:
          - key: high-cpu-node
            operator: In
            values:
            - "true"

这可行,但是并不能阻止所有其他部署在这些高CPU节点上调度Pod。如何指定这些高CPU节点只能在high-cpu-node=true的地方运行pod?

是否可以在不进行和修改所有其他部署配置(我有数十个部署)的情况下执行此操作?

1 个答案:

答案 0 :(得分:1)

要获得此行为,您应该污染节点并在部署上使用容忍度:https://kubernetes.io/docs/concepts/scheduling-eviction/taint-and-toleration/

但是,不幸的是,您必须修改部署。单靠标签是不可能实现的。