一台k8smaster节点故障处理记录

集群原有6个节点,3个master,3 个node

问题:一台master节点物理机出现故障,无法开机

现象:只有2个节点的etcd集群会频繁重启,导致k8s集群一会能连,一会不能连

处理

1、将故障master节点从集群中删除

kubectl delete node xxx

把故障master信息从etcd中删除

etcd的命令可能需要单独下载,我这里下载的是etcd-v3.3.4-linux-adm64.tar.gz

tar zxf etcd-v3.3.4-linux-adm64.tar.gz

cd etcd-v3.3.4-linux-adm64

cp etcdctl /usr/local/sbin

查看etcd成员列表 证书根据自己的环境进行更换

ETCDCTL_API=3 etcdctl --endpoints 127.0.0.1:2379 --cacert /etc/kubernetes/pki/etcd/ca.crt --cert /etc/kubernetes/pki/etcd/server.crt --key /etc/kubernetes/pki/etcd/server.key member list

删除etcd信息

ETCDCTL_API=3 etcdctl --endpoints 127.0.0.1:2379 --cacert /etc/kubernetes/pki/etcd/ca.crt --cert /etc/kubernetes/pki/etcd/server.crt --key /etc/kubernetes/pki/etcd/server.key member remove  xxx

2、将一台nodes节点转换为master节点

2.1  将nodes节点改为不可调度状态

kubectl cordon xxx

2.2  驱逐nodes上的pod

kubectl drain xxx  

2.3  重置此节点

kubectl reset

3、把节点加入集群,当做master节点

3.1 查看token

kubectl token create --print-join-command

3.2 将其它master节点的上证书拷贝到当前节点

3.3  执行3.1查出的命令加入集群  

 后面添加参数  --control-plane

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Kubernetesk8s)的master节点挂掉时,整个Kubernetes集群的管理和控制功能将受到影响。下面是针对这种情况的解释和应对方法。 首先,Kubernetesmaster节点是集群的控制平面,负责管理和协调集群中的所有工作负载。当master节点不可用时,我们需要采取一些措施来恢复和维护集群的稳定运行。 1. 检查并修复故障:首先应该检查master节点的状态,并尝试修复故障。可以通过查看控制平面组件(如kube-apiserver、kube-controller-manager和kube-scheduler)的运行日志来确定问题所在,并尝试重新启动这些组件来恢复服务。 2. 启动新的master节点:如果修复故障的尝试失败或节点无法恢复,则需要启动一个新的master节点。这可以通过创建一个新的虚拟机实例或在现有集群中添加一个新的物理机来实现。然后,我们需要重新配置该节点以成为集群的新的master节点,并确保它能够与其他节点进行通信。 3. 重新初始化集群:如果整个集群的master节点都不可用,并且没有可用的备份或替代节点,则我们需要重新初始化集群。这意味着我们需要重新配置新的master节点,并重新部署和调整在集群中的各个工作负载。这是一个复杂且耗时的过程,需要根据实际情况进行操作。 4. 停用节点故障自动迁移:在恢复或重新初始化新的master节点之前,我们还可以考虑停用节点故障自动迁移(例如使用Kubernetes的DRBD和Pacemaker等手段)。这可以确保在发生故障时,自动将工作负载迁移到其他可用节点上,从而减少对集群的影响。 总之,当Kubernetesmaster节点挂了时,我们需要采取适当的措施来修复或替换节点,并确保集群的正常运行。这可能涉及重新启动组件、添加新节点或重新初始化集群。同时,我们还可以考虑停用节点故障自动迁移来提高集群的可用性和弹性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值