kubernetes-Affinity示例-焦点速读
时间:2023-05-05 12:09:26来源:腾讯云


【资料图】

以下是一个实际的示例,它演示了如何使用Node Affinity规则将Pod调度到指定的Node上。假设我们有三个Node,分别具有以下标签:

Node1:zone=us-east-1aNode2:zone=us-east-1bNode3:zone=us-west-1a

我们希望将一个Pod调度到具有zone=us-east-1a标签的Node上,因此可以使用以下Pod定义文件:

apiVersion: v1kind: Podmetadata:  name: nginxspec:  containers:  - name: nginx    image: nginx  nodeSelector:    zone: us-east-1a

这个Pod定义文件中,nodeSelector部分指定了Pod只能被调度到具有zone=us-east-1a标签的Node上。

另一个示例,演示了如何使用Pod Affinity规则将具有相同标签的Pod调度到同一个Node上。假设我们有两个Pod,分别具有以下标签:

Pod1:app=nginxPod2:app=nginx

我们希望这两个Pod调度到同一个Node上,因此可以使用以下Pod定义文件:

apiVersion: v1kind: Podmetadata:  name: pod1  labels:    app: nginxspec:  containers:  - name: nginx    image: nginx  affinity:    podAffinity:      requiredDuringSchedulingIgnoredDuringExecution:      - labelSelector:          matchExpressions:          - key: app            operator: In            values:            - nginx        topologyKey: kubernetes.io/hostname
apiVersion: v1kind: Podmetadata:  name: pod2  labels:    app: nginxspec:  containers:  - name: nginx    image: nginx  affinity:    podAffinity:      requiredDuringSchedulingIgnoredDuringExecution:      - labelSelector:          matchExpressions:          - key: app            operator: In            values:            - nginx        topologyKey: kubernetes.io/hostname

这两个Pod定义文件中,都使用了相同的affinity规则,即要求具有相同标签的Pod必须调度到同一个Node上。规则中使用了requiredDuringSchedulingIgnoredDuringExecution部分,它要求Pod必须调度到与它具有相同标签的Pod所在的Node上,否则调度失败。topologyKey指定了用来匹配Node的标识符,这里使用的是kubernetes.io/hostname,表示匹配Node的主机名。这个规则要求Pod必须调度到与它具有相同标签的Pod所在的Node上,因此Pod1和Pod2将会被调度到同一个Node上。

标签:

最新
  • kubernetes-Affinity示例-焦点速读

    以下是一个实际的示例,它演示了如何使用NodeAffinity规则将Pod调度到指定的Node上。假设我们有三个Node,

  • 赋然堂:做有“禀赋”、有“使命”的健康守护人

    冬去春来,疫情的阴霾虽已远去,但大众的健康观念已悄然发生改变,人们更加重视自身免疫力的提升,养生

  • 24岁女工猝死公司称是自愿加班 加班猝死公司有责任吗?

    24岁女工猝死 公司称是自愿加班24岁的刘超男死在工厂的宿舍床上,还没等来今年的五一劳动节假期,她原