k8s某pod节点资源使用率过高,如何调整

  1. 用 Descheduler 自动重调度 Pod(推荐) 这是官方工具,能批量迁移过载节点的 Pod 到低负载节点。先部署 Descheduler 到kube-system命名空间,再通过 ConfigMap 配置策略,比如启用HighNodeUtilization策略识别高负载节点,接着它会驱逐符合规则的 Pod,被驱逐的 Pod 会进入 Pending 状态,由原生调度器重新调度到合适节点。还可配置调度周期、驱逐阈值避免频繁迁移。
  2. 手动驱逐 + 重新调度 Pod 适合临时处理少量 Pod。先用kubectl describe node <节点名>确认高负载节点上的非核心 Pod,再执行kubectl drain <节点名> --ignore-daemonsets驱逐节点上 Pod(忽略 DaemonSet 类型),驱逐后 Pod 会由调度器重新分配到其他资源充足节点;若只需驱逐单个 Pod,直接用kubectl delete pod <Pod名>,控制器管理的 Pod 会自动重建并被重新调度。
  3. 就地调整 Pod 资源分配 若仅需优化节点内 Pod 的资源占比,K8s 1.33 + 支持就地调整。用kubectl patch pod <Pod名> -p '{"spec":{"containers":[{"name":"<容器名>","resources":{"requests":{"cpu":"500m","memory":"512Mi"},"limits":{"cpu":"1000m","memory":"1Gi"}}]}}',修改 Pod 的 CPU 和内存请求与限制,Kubelet 会自动适配调整,无需重建 Pod。
  4. 用亲和性约束优化调度规则 长期避免节点过载可配置 Pod 反亲和性。比如在 Deployment 中设置规则,让同一应用的多个 Pod 分散到不同节点,示例中通过podAntiAffinity约束,确保app:web-store的 Pod 不部署在同一节点,从根源减少单节点 Pod 密集导致的资源过高问题。
相关推荐
HHFQ20 小时前
在 systemd 场景下的 CPU 限制方式
linux
道清茗20 小时前
【RH294知识点汇总】第 9 章 《 自动执行 Linux 管理任务 》常见问题
linux·运维·服务器
山羊硬件Time20 小时前
自动化管理Linux的好工具:shell script
linux·嵌入式硬件·硬件工程师·基带工程·硬件开发
wj30558537821 小时前
Codex + Git 开发环境配置指南(WSL版)
linux·运维·git
星马梦缘21 小时前
如何切换window-ubuntu双系统【方案二】
linux·运维·ubuntu
丑八怪大丑1 天前
Java网络编程
linux·服务器·网络
橙子也要努力变强1 天前
信号捕捉底层机制-机理篇2
linux·服务器·c++
运维全栈笔记1 天前
K8S部署Redis高可用全攻略:1主2从3哨兵架构实战
redis·docker·云原生·容器·架构·kubernetes·bootstrap
秋91 天前
MySQL 8.0.46 全平台安装与配置详解(Windows/Linux/macOS)
linux·windows·mysql
尘世壹俗人1 天前
使用K8s部署模型
kubernetes