K8s Pod调度【学习笔记】

Pod调度

先筛选"能运行的节点",再选择"最合适的节点"

一、Pod调度核心流程

K8s调度器主要分为两个阶段:

  1. 节点筛选(Filter)
  2. 节点评分(Score)

二、流程图

三、节点筛选(Filter阶段):

调度器会从所有节点中筛选出"可用节点",主要依据以下条件:

  1. 节点选择(nodeSelecor/nodeAffinity)

根据标签筛选节点,如:

复制代码
nodeSelector:
    xx: yy

指定节点名运行,如

复制代码
nodeName:K8s-master

根据标签亲和性(硬约束)筛选节点,如:

复制代码
affinity:
  nodeAffinity:
    requiredDuringSchedulingIgnoredDuringExecution:
      nodeSelectorTerms:
      - matchExpressions:
        - key: disktype
          operator: In
          values: ["ssd"]
  1. 污点与容忍(Taints & Tolerations)

如果节点有污点,Pod必须有对应容忍才能调度

复制代码
tolereations:
    effect: NoSchedule
    key: xx
    value: yy
    operator: Equal
  1. 资源检查(requests)

判断节点是否有足够CPU/内存资源满足Pod的requests要求

复制代码
resources:
    requests:
        memory: 500Mi

四、节点评分(Score阶段):

在筛选出的节点中,调度器会根据策略进行打分,如:

  • 资源利用率(空闲优先)
  • Pod分布均衡
  • Affinity(preferred)软约束
  • Node负载情况

最终选择最优节点。

五、requests和limits区别

  • requests:调度依据
  • limits:运行限制

六、资源限制对调度影响

  • 当requests设过高时,Pod可能无法调度(Pending状态)
  • 当limits设置过低时,容器可能被限制性能甚至被杀掉

    apiVersion: v1
    kind: Pod
    metadata:
    name: mem-test
    spec:
    containers:
    - name: mem-test
    image: python:3.9
    command: ["python", "-c"]
    args:
    - |
    a = []
    while True:
    a.append(' ' * 10**7)
    resources:
    requests:
    memory: "100Mi"
    limits:
    memory: "200Mi"

相关推荐
henry_20162 小时前
让 AI 编程助手拥有“记忆“:Mem0 OpenMemory MCP 部署到 K8s 全记录(踩坑 + 解决方案)
人工智能·ai·容器·kubernetes·kiro
程序员大辉2 小时前
Beaver Notes(海狸笔记)v4.4.0 中文版 ,开源免费、本地存储、零追踪的笔记软件
笔记·开源
叛逆的小小黄2 小时前
maxent建模结果中响应曲线的美化
经验分享·笔记·r语言·maxent
handler012 小时前
Linux: 基本指令知识点(3)
linux·服务器·c语言·开发语言·c++·笔记
fengci.2 小时前
ctfshow其他(web408-web432)
android·开发语言·前端·学习·php
sensen_kiss3 小时前
CPT306 Principles of Computer Games Design 电脑游戏设计原理 Pt.6 Gameplay 游戏玩法
学习·游戏
程序猿乐锅3 小时前
Java第十三篇:Stream流
java·笔记
殷忆枫3 小时前
AI学习笔记三十六:基于 YOLOv8 与 Qwen3.5 的多模态视频行为分析系统
笔记·学习·yolo
小陈phd3 小时前
多模态大模型学习笔记(三十七)——模型管理平台实战:Ollama本地部署与全流程指南
笔记·学习