概述
etcd 是兼具一致性和高可用性的键值数据库,为云原生架构中重要的基础组件,由CNCF
孵化托管。etcd 在微服务和 Kubernates 集群中不仅可以作为服务注册与发现,还可以作为 key-value 存储的中间件。
先决条件
- 运行的 etcd 集群个数成员为奇数。
- etcd 是一个 leader-based 分布式系统。确保主节点定期向所有从节点发送心跳,以保持集群稳定。
- 保持稳定的 etcd 集群对 Kubernetes 集群的稳定性至关重要。因此,请在专用机器或隔离环境上运行 etcd 集群,以满足所需资源需求]。
- 确保不发生资源不足。
集群的性能和稳定性对网络和磁盘 IO 非常敏感。任何资源匮乏都会导致心跳超时,从而导致集群的不稳定。不稳定的情况表明没有选出任何主节点。在这种情况下,集群不能对其当前状态进行任何更改,这意味着不能调度新的 pod。
相关术语
Raft
:etcd所采用的保证分布式系统强一致性的算法。Node
:节点 ,Raft状态机的一个实例,具有唯一标识。Member
: 成员,一个etcd实例。承载一个Node,且可为客户端请求提供服务。Cluster
:集群,由多个Member构成可以协同工作的etcd集群。Peer
:同伴,Cluster
中其他成员。Proposal
:提议,一个需要完成 raft 协议的请求(例如写请求,配置修改请求)。Client
: 向etcd集群发送HTTP请求的客户端。WAL
:预写式日志,etcd用于持久化存储的日志格式。snapshot
:etcd防止WAL文件过多而设置的快照,存储etcd数据状态。Proxy
:etcd的一种模式,为etcd集群提供反向代理服务。Leader
:Raft算法中通过竞选而产生的处理所有数据提交的节点。Follower
:竞选失败的节点作为Raft中的从属节点,为算法提供强一致性保证。Candidate
:当Follower超过一定时间接收不到Leader的心跳时转变为Candidate开始竞选。Term
:某个节点成为Leader到下一次竞选时间,称为Ubuntu一个Term。Index
:数据项编号。Raft中通过Term和Index来定位数据。
ETCD 部署
源码安装
基于master分支构建etcd
|
|
启动命令
--listen-client-urls
于 --listen-peer-urls
不能为域名
--listen-client-urls
于 --advertise-client-urls
|
|
其他方式
- CentOS 可以使用
yum install etcd -y
- Ubuntu 可以预构建的二进制文件
安装报错
certificate: x509: certificate specifies an incompatible key usage
原因:此处证书用于
serverAuth
与clientAuth
,缺少clientAuth
导致解决:
extendedKeyUsage=serverAuth, clientAuth
|
|
原因:证书使用的者不对。
解决:查看
subjectAltName
是否与请求地址一致。
|
|
原因:
ETCD_LISTEN_PEER_URLS
与ETCD_LISTEN_CLIENT_URLS
不能用域名
|
|
error #0: x509: certificate has expired or is not yet valid
原因:证书还未生效
解决:因服务器时间不对导致,校对时间后正常
|
|
配置文件详解
etcdctl 使用
|
|
v3 版本客户端使用
|
|
日志独立
etcd日志默认输出到 /var/log/message
如果想独立日志为一个文件,可以使用rsyslogd过滤器功能,使etcd的日志输出到单独的文件内。
- 新建
/etc/rsyslog.d/xx.conf
文件。 - 在新建文件内写入内容如下
|
|
也可以
|
|