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 下线节点

节点关机

断电

修机器

随便操作即可

相关推荐
一夜空中最亮的星一18 分钟前
【Linux】ubuntu24.04 安装docker
linux·docker·eureka
赖small强23 分钟前
【Linux 网络基础】libwebsockets 技术文档
linux·网络·https·tls·lib·websockets
炸裂狸花猫30 分钟前
开源域名证书工具 - cert-manager
云原生·容器·kubernetes·开源·cert-manager
q***518944 分钟前
ubuntu 安装 Redis
linux·redis·ubuntu
会飞的小蛮猪1 小时前
Ubuntu24.04基于Docker部署K8s(使用私服部署)
经验分享·docker·云原生·容器·kubernetes
q***47182 小时前
使用Canal将MySQL数据同步到ES(Linux)
linux·mysql·elasticsearch
Y淑滢潇潇3 小时前
RHCE 防火墙实验
linux·运维·rhce
wadesir3 小时前
当前位置:首页 > 服务器技术 > 正文Linux网络HSRP协议(实现路由器热备份与高可用性的实用指南)
linux·服务器·网络
稻谷君W3 小时前
Ubuntu 远程访问 Win11 WSL2 并固定访问教程
linux·运维·ubuntu
wdfk_prog4 小时前
[Linux]学习笔记系列 -- [kernel]workqueue
linux·笔记·学习