etcd集群搭建

简介: etcd集群搭建

etcd是由一家位于旧金山的初创公司CoreOS公司(现已被Red Hat收购)于2013年6月发起的开源项目,旨在构建一个高可用的分布式键值(key-value)存储系统。CoreOS系统通过etcd来解决分布式系统配置信息共享、服务发现等问题。

etcd这个名字由两部分组成:etc和d,即UNIX/Linux操作系统的“/etc”目录和分布式(distributed)首字母的“d”。我们都知道,/etc目录一般用于存储UNIX/Linux操作系统的配置信息,因此etc和d合起来就是一个分布式的/etc目录。由此可见,etcd的寓意是为大规模分布式系统存储配置信息。

一个etcd集群要求有三个节点,配置相对简单,记录如下(以v3.5.9为例):

例子中三台服务器的IP地址:192.168.0.1、192.168.0.2、192.168.0.3

一、下载及安装

wget https://github.com/etcd-io/etcd/releases/download/v3.5.9/etcd-v3.5.9-linux-amd64.tar.gz
tar xvf etcd-v3.5.9-linux-amd64.tar.gz
mv etcd-v3.5.9-linux-amd64 /usr/local/etcd
#查看etcd版本/usr/local/etcd/etcd -–version
/usr/local/etcd/etcdctl version

二、配置

cd /usr/local/etcd
vi etcd.yaml

参数

name

[node01][node02][node03]三个节点分别配置不同的值

data-dir

/data/etcd

listen-client-urls

http://0.0.0.0:2379

advertise-client-urls

http://[本机IP地址]:2379

listen-peer-urls

http://[本机IP地址]:2380

initial-advertise-peer-urls

http://[本机IP地址]:2380

initial-cluster

node01=http://[node01 IP地址]:2380,

node02=http://[node02 IP地址]:2380,

node03=http://[node03 IP地址]:2380

initial-cluster-token

etcd-pg-cluster

initial-cluster-state

new

node1(192.168.0.1)配置文件:

name: 'node01'data-dir: '/data/etcd'listen-client-urls: 'http://0.0.0.0:2379'advertise-client-urls: 'http://192.168.0.1:2379'listen-peer-urls: 'http://192.168.0.1:2380'initial-advertise-peer-urls: 'http://192.168.0.1:2380'initial-cluster: 'node01=http://192.168.0.1:2380,node02=http://192.168.0.2:2380,node03=http://192.168.0.3:2380'

node2(192.168.0.2)配置文件:

name: 'node02'data-dir: '/data/etcd'listen-client-urls: 'http://0.0.0.0:2379'advertise-client-urls: 'http://192.168.0.2:2379'listen-peer-urls: 'http://192.168.0.2:2380'initial-advertise-peer-urls: 'http://192.168.0.2:2380'initial-cluster: 'node01=http://192.168.0.1:2380,node02=http://192.168.0.2:2380,node03=http://192.168.0.3:2380'

node3(192.168.0.3)配置文件:

name: 'node01'data-dir: '/data/etcd'listen-client-urls: 'http://0.0.0.0:2379'advertise-client-urls: 'http://192.168.0.3:2379'listen-peer-urls: 'http://192.168.0.3:2380'initial-advertise-peer-urls: 'http://192.168.0.3:2380'initial-cluster: 'node01=http://192.168.0.1:2380,node02=http://192.168.0.2:2380,node03=http://192.168.0.3:2380'

三、启动etcd

etcd –config-file=/usr/local/etcd/etcd.yaml &

四、验证etcd

etcdctl endpoint status --endpoints=http://192.168.0.1:2380,http://192.168.0.2:2380,http://192.168.0.3:2380 -w table

验证无误后,可通过systemd开机启动

# vi /lib/systemd/system/etcd.servce[Unit]
Description=Etcd Server
After=network.target
After=network-online.target
Wants=network-online.target
[Service]
Type=notify
WorkingDirectory=/usr/local/etcd/
EnvironmentFile=-/usr/local/etcd/etcd.yaml
User=runner
# set GOMAXPROCS to number of processorsRestart=on-failure
LimitNOFILE=65536ExecStart=/usr/local/etcd/etcd --config-file=/usr/local/etcd/etcd.yaml
[Install]
WantedBy=multi-user.target
# systemctl enable etcd.service# systemctl start etcd# systemctl status etcd




相关文章
|
存储 JSON NoSQL
ETCD教程-4.深入ETCD
目前etcd主要经历了3个大的版本,分别为etcd 0.4版本、etcd 2.0版本和etcd 3.0版本。
901 0
ETCD教程-4.深入ETCD
|
5月前
|
存储 Kubernetes 算法
在K8S中,etcd 及其特点?
在K8S中,etcd 及其特点?
|
5月前
|
存储 Kubernetes API
在K8S中,etcd 适应的场景?
在K8S中,etcd 适应的场景?
|
5月前
|
存储 Kubernetes 负载均衡
在K8S中,etcd适应的场景有哪些?
在K8S中,etcd适应的场景有哪些?
|
JSON API Go
etcd的安装和使用
etcd的安装和使用
227 0
|
8月前
|
存储 负载均衡 算法
1. Etcd 介绍
1. Etcd 介绍
|
8月前
|
算法 Java Go
ETCD(六)ETCD和Zookeeper
ETCD(六)ETCD和Zookeeper
176 0
|
存储 算法 安全
Etcd 初步认识
近期在接触的新项目中在使用Etcd,但是在使用的过程中公司对其的使用仅使用服务注册的功能,并未将其发挥真正的用处。学习一波,将来可以在项目中使用进行改进。
268 0
|
存储 监控 算法
ETCD教程-1.ETCD介绍
etcd是一个Go言编写的分布式、高可用的一致性键值存储系统,用于提供可靠的分布式键值存储、配置共享和服务发现等功能
591 0
ETCD教程-1.ETCD介绍
|
存储 NoSQL 调度
Etcd基本部署与使用
Etcd基本部署与使用
1193 0