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

相关推荐
咖啡啡不加糖17 分钟前
深入理解MySQL死锁:从原理、案例到解决方案
java·数据库·mysql
文牧之17 分钟前
PostgreSQL 的扩展pageinspect
运维·数据库·postgresql
要努力啊啊啊26 分钟前
使用 Python + SQLAlchemy 创建知识库数据库(SQLite)—— 构建本地知识库系统的基础《一》
数据库·人工智能·python·深度学习·自然语言处理·sqlite
KENYCHEN奉孝28 分钟前
Django CMS 的 Demo
数据库·sqlite
为中华崛起而奋斗1 小时前
Oracle 19c RAC集群ADG搭建
数据库·oracle
betazhou2 小时前
mariadb5.5.56在centos7.6环境安装
android·数据库·adb·mariadb·msyql
开挖掘机上班2 小时前
mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包
数据库·mysql
花月C2 小时前
Mysql-定时删除数据库中的验证码
数据库·后端·mysql·spring
success_a4 小时前
大故障:阿里云核心域名爆炸了
数据库·阿里云·云计算