K8S 集群节点缩容

环境说明:

|-------------|----------------|--------|--------|---------|----------|
| 主机名 | IP地址 | CPU/内存 | 角色 | K8S版本 | Docker版本 |
| k8s231 | 192.168.99.231 | 2C4G | master | 1.23.17 | 20.10.24 |
| k8s232 | 192.168.99.232 | 2C4G | woker | 1.23.17 | 20.10.24 |
| k8s233(需下线) | 192.168.99.233 | 2C4G | woker | 1.23.17 | 20.10.24 |

1. K8S 集群节点缩容

当集群中有闲置或者node因为硬件故障机其他原因需要下线时就需要对集群进行缩容

1.1 查看现有节点信息

bash 复制代码
kubectl get nodes

如图:

可以看到当前所有部署在k8s233节点上面的Pod

1.2 驱逐 Pod 并打 SchedulingDisable 标签,但 ds 资源创建的Pod不会驱逐

bash 复制代码
kubectl drain k8s233 --ignore-daemonsets --delete-emptydir-data

如图:

之前k8s233节点上的资源被驱逐到其他节点上了

如图:

ds资源并没有被驱逐

1.3 查看节点被标记为禁用调度状态

bash 复制代码
#标记当前节点不可调度Pod,那么master组件的scheduler 就不会调度到Pod当前节点
[root@k8s231 /app/manifests/sts]# kubectl get nodes

1.4给需要下线的节点打污点,驱逐已经调度到该节点的所有Pod

bash 复制代码
1.#打污点,不可调度且驱逐
kubectl taint node k8s233 school=bihuang:NoExecute


2.#查看节点污点
kubectl describe nodes | grep Taints -A 2

注意:

kube-proxy组件貌似无法被驱逐,因为配置无视污点的属性,所以打任何污点都无效!

1.5 下线节点重置

bash 复制代码
[root@k8s233 ~]# kubeadm reset --f

[root@k8s233 ~]# rm -rf /etc/cni/net.d && iptables -F && iptables-save 

[root@k8s233 ~]# systemctl disable --now kubelet

1.6 删除节点

bash 复制代码
[root@k8s231 /app/manifests/sts]# kubectl delete nodes k8s233

1.7 下线节点

节点关机

断电

修机器

随便操作即可

相关推荐
Evan芙14 分钟前
Linux 进程状态与进程管理命令
linux·运维·服务器
码农12138号1 小时前
Bugku HackINI 2022 Whois 详解
linux·web安全·ctf·命令执行·bugku·换行符
Joren的学习记录1 小时前
【Linux运维进阶知识】Nginx负载均衡
linux·运维·nginx
用户2190326527351 小时前
Java后端必须的Docker 部署 Redis 集群完整指南
linux·后端
胡先生不姓胡2 小时前
如何获取跨系统调用的函数调用栈
linux
里纽斯3 小时前
RK平台Watchdog硬件看门狗验证
android·linux·rk3588·watchdog·看门狗·rk平台·wtd
chem41113 小时前
魔百盒 私有网盘seafile搭建
linux·运维·网络
早睡的叶子4 小时前
VM / IREE 的调度器架构
linux·运维·架构
兄台の请冷静4 小时前
linux 安装sentinel 并加入systemctl
linux·运维·sentinel
skywalk81634 小时前
postmarketos一个专为智能手机和平板设备设计的开源 Linux 发行版 支持红米2
linux·智能手机·电脑