Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【每日一个云原生小技巧 #75】Kubernetes 指定 Pod 所在节点

【每日一个云原生小技巧 #75】Kubernetes 指定 Pod 所在节点

作者头像
郭旭东
发布于 2024-02-04 03:11:16
发布于 2024-02-04 03:11:16
22000
代码可运行
举报
文章被收录于专栏:云原生工具箱云原生工具箱
运行总次数:0
代码可运行
在 Kubernetes 中,将 Pod 指派给节点是一个重要的调度过程。Kubernetes 集群中的控制平面(Control Plane)负责管理节点和 Pod,确保它们按照期望的状态运行。将 Pod 指派给节点,即是通过调度器(Scheduler)来决定 Pod 应该运行在哪个节点上。这一过程涉及到多个因素,如资源需求、硬件/软件约束、亲和性/反亲和性规则等。

使用场景

  1. 资源分配:根据 Pod 的资源需求(如 CPU、内存)和节点的可用资源,调度器选择最合适的节点。
  2. 亲和性与反亲和性:通过标签选择器,可以指定 Pod 应该或者不应该与某些节点一起运行。
  3. 数据局部性:对于需要访问特定数据(如本地存储)的应用,可以通过节点选择器将 Pod 调度到特定节点。
  4. 异常处理:当节点出现问题时,系统可能需要将 Pod 从故障节点移动到健康的节点。

使用技巧

  1. 资源预留:为系统组件预留资源,确保关键服务不受资源竞争影响。
  2. 标签和选择器:合理使用标签(label)和选择器(selector),以便更好地控制 Pod 的分布。
  3. 污点和容忍度:设置节点的污点(taint)以阻止 Pod 调度到特定节点,同时为 Pod 设置容忍度(toleration)以允许它们在某些情况下被调度到这些节点。
  4. 优先级和抢占:通过设置 Pod 的优先级和抢占策略,可以确保高优先级的应用获得所需资源。

使用案例

假设我们有一个 Web 应用和一个数据库服务,我们希望它们运行在不同的节点上以提高系统的可靠性。

  1. 为节点打标签
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
kubectl label nodes node1 role=web
kubectl label nodes node2 role=db
  1. 配置 Pod 规约:Web 应用的 Pod 规约:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
apiVersion: v1
kind: Pod
metadata:
  name: web-app
spec:
  nodeSelector:
    role: web
  containers:
  - name: web-app
    image: web-app-image

数据库服务的 Pod 规约:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
apiVersion: v1
kind: Pod
metadata:
  name: db-service
spec:
  nodeSelector:
    role: db
  containers:
  - name: db-service
    image: db-service-image

通过上述配置,Web 应用的 Pod 将只被调度到标签为 role=web 的节点上,而数据库服务的 Pod 将只被调度到标签为 role=db 的节点上。这样,我们就可以确保 Web 应用和数据库服务运行在不同的节点上,从而提高系统的可靠性。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-01-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 云原生之路 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
这应该是最全的K8s-Pod调度策略了
API Server接受客户端提交Pod对象创建请求后的操作过程中,有一个重要的步骤就是由调度器程序kube-scheduler从当前集群中选择一个可用的最佳节点来接收并运行它,通常是默认的调度器kube-scheduler负责执行此类任务。
小小科
2020/06/15
19.1K0
浅入Kubernetes(10):控制节点的部署,选择器、亲和性、污点
在前面的学习中,我们学到了 Deployment 部署,以及副本数(ReplicaSet),但是 Pod 部署到哪个 Worker 节点是随机,即使有 3个 Woker 和设定 3个 副本,不一定每个 Node 刚刚好运行一个 Pod,也可能其中 Node 运行着三个副本。
痴者工良
2021/04/26
8750
【K8S专栏】Kubernetes调度管理
在日常工作中,每个机场都有调度室,用来管理飞机应该从哪里降落,停在什么地方。在Kubernetes也有这样的调度器,主要作用就是将Pod安排到合适的节点上。
没有故事的陈师傅
2022/09/15
6650
【K8S专栏】Kubernetes调度管理
Kubernetes之调度篇
这边肯定会有其他场景也会有对pod的调度有特殊要求,这边只是列举了其中几个情况,对于上述遇到的情况我们需要怎么处理,其实k8s给我们提供了丰富的调度策略来满足我们的需求。下面我们来一一说下这些调度策略。
聂伟星
2020/08/25
1.5K0
Kubernetes 的亲和性污点与容忍
我们在使用k8s过程中经常有这样的需求:我的k8s集群有多台服务器,配置不尽相同。我想把数据库部署到CPU、内存比较好的这几台机;我想把静态承载服务部署到有固态硬盘的机器等;而这些需求,就是我们今天要讲的k8s的调度:
乔达摩@嘿
2023/03/23
7910
Kubernetes 的亲和性污点与容忍
Kubernetes 调度和驱逐
kubectl通过读取集群配置文件 ~/.kube/config 将请求发给apiserver,之后apiserver将创建pod的属性信息写入到etcd中,etcd会响应一个状态给apiserver,保存etcd成功会在控制台显示pod/<pod名称> created,之后调度组件scheduler上线,负责将新的pod分配到合适的节点上,调度之后,将结果响应给apiserver,apiserver再将结果保存到etcd中,kubelet当发现有个pod被绑定到自己的节点上时,就会调用docker的api去创建容器,容器创建之后,docekr会返回一个状态给kubelet,创建成功之后,kubelet再通知apiserver容器状态,之后apiserver再将状态写入到etcd中,之后就可以使用kubelet get pod去查看pod的状态了
匿名用户的日记
2021/12/14
7250
Kubernetes 调度和驱逐
K8s调度策略
在K8s中,调度是指将Pod放置到合适的节点上。调度器通过 K8s 的监测机制来发现集群中新创建且尚未被调度到节点上的Pod。 调度器会将所发现的每一个未调度的Pod调度到一个合适的节点上来运行。
谢公子
2023/02/27
1.1K0
K8s调度策略
8-Kubernetes入门基础之调度器与亲和性介绍
priority 选项 描述: 优先级由一系列键值对组成,键是该优先级项的名称,值是它的权重(非常重要)一般得权重越高即优先级越高,通过算法对所有的优先级项目和权重进行计算得出最终的结果; 这些优先级选项包括:
全栈工程师修炼指南
2022/09/29
7890
Kubernetes (K8S)中深入理解Pods调度
我们部署的 Pod 是通过集群的自动调度策略来选择节点的,默认情况下调度器考虑的是资源足够,并且负载尽量平均,但是有的时候我们需要能够更加细粒度的去控制 Pod 的调度,比如我们希望一些机器学习的应用只跑在有 GPU 的节点上;但是有的时候我们的服务之间交流比较频繁,又希望能够将这服务的 Pod 都调度到同一个的节点上。这就需要使用一些调度方式来控制 Pod 的调度了,主要有两个概念:亲和性和反亲和性,亲和性又分成节点亲和性(nodeAffinity)和 Pod 亲和性(podAffinity)。
王先森sec
2023/10/17
7140
Kubernetes 之集群调度
我们现在有这样一个需求,就是集群中多台服务的配置是不一致的。这就导致资源分配并不是均匀的,比如我们需要有些服务节点用来运行计算密集型的服务,而有些服务节点来运行需要大量内存的服务。而在 k8s 中当然也配置了相关服务来处理上述的问题,那就是 Scheduler。
民工哥
2021/04/21
8060
k8s 服务升级为啥 pod 会部署到我们不期望的节点上??看来你还不懂污点和容忍度
做自动化的同事今天居然问我 k8s 中为什么我部署的 pod 会跑到你们开发的节点上来?我可以去控制它吗?🧐🧐
阿兵云原生
2023/09/27
2880
k8s 服务升级为啥 pod 会部署到我们不期望的节点上??看来你还不懂污点和容忍度
图文并茂带你解读 Kube-scheduler
Hello folks,今天为大家分享一个由 ContainerLabs 出品的关于 Kubernetes Scheduler 的文章。
Luga Lee
2023/02/14
8640
图文并茂带你解读  Kube-scheduler
Kubernetes | 集群调度 - ClusterScheduling
Scheduler 是 Kubernetes 的调度器,主要的任务是把定义的 pod 分配到集群的节点上。听起来非常简单,但有很多要考虑的问题:
Zkeq
2023/05/14
4600
Kubernetes | 集群调度 - ClusterScheduling
k8s pod调度_调度方式
在默认情况下,一个Pod在哪个Node节点上运行,是由Scheduler组件采用相应的算法计算出来的,这个过程是不受人工控制的。但是在实际使用中,这并不满足需求,因为很多情况下,我们想控制某些Pod到达某些节点上,那么应该怎么做?这就要求了解kubernetes对Pod的调度规则,kubernetes提供了四大类调度方式。
全栈程序员站长
2022/09/22
9280
kubernetes高级调度的一些方式
nodeAffinity有两种,优选和必选,其为:preferredDuringSchedulingIgnoredDuringExecution和requiredDuringSchedulingIgnoredDuringExecution。
极客运维圈
2020/03/21
4190
13个鲜为人知的Kubernetes技巧
Kubernetes 具备完整的生态系统,提供了许多功能,可以显著增强容器化应用程序的管理、可伸缩性和安全性。以下是 13 个技巧,每个都详细说明了技巧解释、使用示例、上下文应用以及注意事项。
云云众生s
2024/03/28
1940
Kubernetes Pod详解
Pod中通过共享Network Namespace的方式进行网络的共享,但是如果是以下方式进行Network Namespace共享会有问题:
shysh95
2022/05/24
8300
Kubernetes Pod详解
Kubernetes中资源的管理与调度
不知道有没有小伙伴跟我一样在集群创建应用的时候没有详细计算过自己的资源配比。然后我是看到kubectl top node 一看每个节点还有很多的资源,就直接创建了几个资源配比较高的应用,而且这几个应用是高负载运行的....然后的结果就是集群中好多应用开始崩溃了......
对你无可奈何
2021/06/24
1.5K0
k8s 实践经验(五)pod 详解(2)
在讲解本章之前,我先通过一个故事,来描绘一下 k8s 中 node 和 pod 的爱恨情仇。
看、未来
2022/05/09
6710
k8s 实践经验(五)pod 详解(2)
K8s pod详解
○ 可以在根容器上设置IP地址,其它容器都共享此IP(Pod的IP),以实现Pod内部的网络通信(这里是Pod内部的通讯,Pod之间的通讯采用虚拟二层网络技术来实现,我们当前环境使用的是Flannel)。
大忽悠爱学习
2022/09/27
2.1K0
K8s pod详解
相关推荐
这应该是最全的K8s-Pod调度策略了
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验