nginx亲和性配置

一、使用如下yaml即可

apiVersion: apps/v1
kind: Deployment
metadata:
  annotations:
    deployment.kubernetes.io/revision: "1"
  generation: 1
  labels:
    k8s-app: nginx
    qcloud-app: nginx
  managedFields:
  - apiVersion: apps/v1
    manager: tke-apiserver
    operation: Update
  - apiVersion: apps/v1
    manager: kube-controller-manager
    operation: Update
  name: nginx3
  namespace: default
spec:
  progressDeadlineSeconds: 600
  replicas: 1
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      k8s-app: nginx
  strategy:
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 0
    type: RollingUpdate
  template:
    metadata:
      labels:
        k8s-app: nginx
        qcloud-app: nginx
    spec:
      affinity:
        nodeAffinity:
          preferredDuringSchedulingIgnoredDuringExecution:          #尽量满足条件(调度期间如果满足其中一个亲和性条件则调度到对应node,如果没有节点满足条件则随机调度到任意节点)
          - preference:
              matchExpressions:
              - key: kubernetes
                operator: In
                values:
                - ljx1
            weight: 1
          requiredDuringSchedulingIgnoredDuringExecution:         #强制满足条件(调度期间如果满足其中一个亲和性条件则调度到对应node,如果没有节点满足条件则调度失败)
            nodeSelectorTerms:
            - matchExpressions:
              - key: kubernetes
                operator: In
                values:
                - ljx
      containers:
      - image: nginx:latest
        imagePullPolicy: Always
        lifecycle:
            postStart:
              exec:
                command:
                  - /bin/sh
                  - '-c'
                  - su -s /bin/sh -c " chmod -R 777 /data/log/nginxlog"
        name: nginx
        resources:
          limits:
            cpu: 500m
            memory: 256Mi
          requests:
            cpu: 250m
            memory: 128Mi
        securityContext:
          privileged: false
      dnsPolicy: ClusterFirst
      imagePullSecrets:
      - name: secret
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      terminationGracePeriodSeconds: 30

二、node节点添加label方法

添加label语法
kubectl label nodes <node-name> <label-key>=<label-value> 

添加lebel示例
kubectl label node node1 kubernetes=ljx

查看node节点label
kubectl get node --show-labels

三、node节点删除label方法

删除label语法
kubectl label nodes <node-name> <label-key>-

删除label示例
kubectl label node node1 kubernetes-
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

运维那些事~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值