k8s特殊节点,特殊应用,节点只部署该应用,应用只部署在该节点。

在 Kubernetes 集群中,你可以通过使用 nodeSelectornodeAffinitytaintstolerations 来将一个 deployment 部署到指定的节点上,并确保该节点上只运行此 deployment。以下是具体步骤:

  1. 给目标节点打标签

    选择一个节点,并给它打上一个唯一的标签。比如你可以将节点打上 role=dev-node 标签:

    bash 复制代码
    kubectl label nodes <your-node-name> role=dev-node
  2. 使用 nodeSelector 绑定 Deployment 到特定节点

    在你的 Deployment 配置文件中,使用 nodeSelector 将该 Deployment 绑定到带有特定标签的节点上。以下是一个示例配置:

    yaml 复制代码
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: dev-deployment
    spec:
      replicas: 1
      selector:
        matchLabels:
          app: dev-app
      template:
        metadata:
          labels:
            app: dev-app
        spec:
          containers:
          - name: dev-container
            image: your-image:latest
          nodeSelector:
            role: dev-node
  3. 给节点添加 taint

    为确保该节点只运行此 deployment,你可以给该节点添加一个 taint,使得其他 deployment 无法调度到该节点。比如:

    bash 复制代码
    kubectl taint nodes <your-node-name> dedicated=dev:NoSchedule
  4. 在 Deployment 中添加 tolerations

    在 Deployment 配置文件中添加 tolerations,允许其调度到有 taint 的节点上:

    yaml 复制代码
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: dev-deployment
    spec:
      replicas: 1
      selector:
        matchLabels:
          app: dev-app
      template:
        metadata:
          labels:
            app: dev-app
        spec:
          containers:
          - name: dev-container
            image: your-image:latest
          nodeSelector:
            role: dev-node
          tolerations:
          - key: "dedicated"
            operator: "Equal"
            value: "dev"
            effect: "NoSchedule"

通过以上步骤,你可以确保你的 dev-deployment 只部署在指定节点上,并且该节点上只能部署这个 dev-deployment

相关推荐
小锋学长生活大爆炸25 分钟前
【教程】Docker更换存储位置
运维·docker·容器
gnufre1 小时前
Kubernetes 1.28 无 Docker 运行时环境下的容器化构建实践:Kaniko + Jenkins 全链路详解
kubernetes·jenkins·kaniko
Akamai中国4 小时前
分布式AI推理的成功之道
人工智能·分布式·云原生·云计算·云服务·云平台·云主机
川石教育4 小时前
测试工程师如何学会Kubernetes(k8s)容器知识
云原生·容器·kubernetes·kubernetes容器·kubernetes教程
iRayCheung5 小时前
Kind方式部署k8s单节点集群并创建nginx服务对外访问
nginx·kubernetes·kind
小黑_深呼吸6 小时前
Prometheus实战教程:k8s平台-Mysql监控案例
运维·学习·kubernetes·prometheus
THMAIL6 小时前
mac M芯片运行docker-desktop异常问题
macos·docker·容器
家庭云计算专家8 小时前
还没用过智能文档编辑器吗?带有AI插件的ONLYOFFICE介绍
服务器·人工智能·docker·容器·编辑器
匆匆z28 小时前
AWS EC2 微服务 金丝雀发布(Canary Release)方案
微服务·云原生·金丝雀部署
富士康质检员张全蛋8 小时前
云原生|kubernetes|kubernetes的etcd集群备份策略
云原生·kubernetes·etcd