etcd三节点,其中一个坏掉了的恢复办法

一、配置etcdctl环境变量


#其中证书实际路径和endpoints,以环境情况为准,查询方式

ps -ef | grep 'etcd-cafile'

ps -ef | grep 'etcd-servers'

export ETCDCTL_API=3

export ETCDCTL_CACERT=/etc/kubernetes/ssl/etcd/ca.crt

export ETCDCTL_CERT=/etc/kubernetes/ssl/etcd/etcdctl-etcd-client.crt

export ETCDCTL_KEY=/etc/kubernetes/ssl/etcd/etcdctl-etcd-client.key

export ETCDCTL_DIAL_TIMEOUT=3s

export ETCDCTL_ENDPOINTS=https://10.12.107.99:2379,https://10.12.107.100:2379,https://10.12.107.101:2379


二、确保有etcdctl命令,如果没有去官网下载二进制包安装即可

三、从集群中剔除故障节点(确保故障节点etcd服务已停止 systemctl stop etcd)

#集群成员信息

etcdctl -wtable member list

#集群主从同步情况

etcdctl -wtable endpoint status

etcdctl -wtable endpoint health

摘除一个节点

etcdctl member remove 成员id

四、清空故障节点etcd的数据目录

mv /var/lib/etcd /var/lib/etcd_bak

五、加入节点 (确保etcd启动参数etcd.env中--initial-cluster-state 为existing)

etcdctl member add 成员名称(主机名) --peer-urls=https://10.8.47.13:2380

六、启动etcd服务

systemctl start etcd

相关推荐
BugShare8 小时前
Mac 上原生开发的开源免费、尽享丝滑数据库工具
数据库·macos·开源
Java爱好狂.8 小时前
阿里1658页2026最新Java面试题总结(含答案)
数据库·redis·程序员·java面试·java面试题·java编程·java八股文
jieyucx8 小时前
《Go 数据库编程开篇:彻底打通 database/sql 与 MySQL 驱动的连接池调优密码》
数据库·sql·golang
白露与泡影8 小时前
深入理解MySQL事务隔离级别:MVCC机制与Next-Key Lock如何解决幻读问题?
数据库·mysql
Gong-Yu8 小时前
MySQL数据库运维——性能优化进阶2️⃣
运维·数据库·mysql·性能优化
吴声子夜歌8 小时前
SQL经典实例——概述
数据库·sql
布朗克1688 小时前
40 Redis与微服务入门
java·数据库·redis·微服务
biubiubiu07068 小时前
Ubuntu中3种定时任务
数据库·ubuntu·postgresql
我是大猴子8 小时前
Stream流式编程
数据库·sql