分布式键值高可用存储集群架构搭建(ETCD)-创新互联

   ETCD 是一个高可用的分布式键值数据库,可用于服务发现。ETCD 采用 raft 一致性算法,基于 Go 语言实现,随着CoreOS和Kubernetes等项目在开源社区日益火热,它们项目中都用到的etcd组件作为一个高可用强一致性的服务发现存储仓库,渐渐为开发人员所关注。在云计算时代,如何让服务快速透明地接入到计算集群中,如何让共享配置信息快速被集群中的所有机器发现,更为重要的是,如何构建这样一套高可用、安全、易于部署以及响应快速的服务集群,已经成为了迫切需要解决的问题。etcd为解决这类问题带来了福音,本文将从etcd的应用场景开始,深入解读etcd的实现方式,以供开发者们更为充分地享用etcd所带来的便利。

特点
简单:安装配置使用简单,提供 HTTP API
安全:支持 SSL 证书
可靠:采用 raft 算法,实现分布式系统数据的可用性和一致性
下载安装包:
[root@master ~]# wget https://github.com/coreos/etcd/releases/download/v3.3.2/etcd-v3.3.2-linux-amd64.tar.gz
分布式键值高可用存储集群架构搭建(ETCD)
复制安装包到各接点:
[root@master ~]# ansible k8s -m copy -a'src=/root/etcd-v3.3.2-linux-amd64.tar.gz dest=/root/'
分布式键值高可用存储集群架构搭建(ETCD)
部署环境三台机子:IP--主机名--集群结点名
192.168.27.211 client1 (etcd1)
192.168.27.212 client2 (etcd2)
192.168.27.213 client3 (etcd3)

创新互联公司不只是一家网站建设的网络公司;我们对营销、技术、服务都有自己独特见解,公司采取“创意+综合+营销”一体化的方式为您提供更专业的服务!我们经历的每一步也许不一定是最完美的,但每一步都有值得深思的意义。我们珍视每一份信任,关注我们的网站制作、成都做网站质量和服务品质,在得到用户满意的同时,也能得到同行业的专业认可,能够为行业创新发展助力。未来将继续专注于技术创新,服务升级,满足企业一站式网络营销推广需求,让再小的成都品牌网站建设也能产生价值!
  1. 解压版本包
    tar -zxvf etcd-v3.3.2-linux-amd64.tar.gz 或 [root@master ~]# ansible k8s -m shell -a'tar -zxf etcd-v3.3.2-linux-amd64.tar.gz'
    分布式键值高可用存储集群架构搭建(ETCD)
    分布式键值高可用存储集群架构搭建(ETCD)
  2. 将解压文件重命名并移到/etc/目录下
    mv etcd-v3.3.2-linux-amd64 /etc/etcd-v3.3.2 或
    [root@master ~]# ansible k8s -m shell -a'mv etcd-v3.3.2-linux-amd64 /etc/etcd-v3.3.2'
    分布式键值高可用存储集群架构搭建(ETCD)
  3. 将etcd和etcdctl加入系统变量PATH中(可以省略)
    [root@master ~]# ansible k8s -m shell -a'echo export PATH=/etc/etcd-v3.3.2:$PATH >> ~/.bashrc'
    [root@master ~]# ansible k8s -m shell -a'source ~/.bashrc '
    [root@master ~]# ansible k8s -m shell -a'source /root/.bashrc ' #靠普些
    分布式键值高可用存储集群架构搭建(ETCD)
    分布式键值高可用存储集群架构搭建(ETCD)
    4.进入/etc/etcd-v3.3.2,并创建配置文件etcd.conf,内容:
    分布式键值高可用存储集群架构搭建(ETCD)
    分布式键值高可用存储集群架构搭建(ETCD)
    name: etcd1
    data-dir: /etc/etcd-v3.3.2/data
    listen-client-urls: http://0.0.0.0:2379
    advertise-client-urls: http://192.168.27.211:2379
    listen-peer-urls: http://0.0.0.0:2380
    initial-advertise-peer-urls: http://192.168.27.211:2380
    initial-cluster: etcd1=http://192.168.27.211:2380,etcd2=http://192.168.27.212:2380,etcd3=http://192.168.27.213:2380
    initial-cluster-token: etcd-cluster-my
    initial-cluster-state: new
    5.设置etcd版本号,默认为2,我们安装的版本为3.3.2,所以此处设置为3
    分布式键值高可用存储集群架构搭建(ETCD)
    在 文件~/.bashrc中加入一行改为3
    export ETCDCTL_API=3
    分布式键值高可用存储集群架构搭建(ETCD)
    分布式键值高可用存储集群架构搭建(ETCD)
    分布式键值高可用存储集群架构搭建(ETCD)
  4. 设置开机启动,新建文件/usr/lib/systemd/system/etcd.service,设置方便管理配置内容:
    [root@client1 etcd-v3.3.2]# cat /usr/lib/systemd/system/etcd.service
    [Unit]
    Description=Etcd Server
    After=network.target
    After=network-online.target
    Wants=network-online.target

[Service]
Type=notify
WorkingDirectory=/etc/etcd-v3.3.2
#User=etcd
ExecStart=/etc/etcd-v3.3.2/etcd --config-file /etc/etcd-v3.3.2/etcd.conf
Restart=on-failure
LimitNOFILE=65536

[Install]
WantedBy=multi-user.target

  1. 启动etcd,启动第一个member的时候,此member等待其它member初始化完毕,处于watting状态,此时紧接着启动第二个就行了
    systemctl daemon-reload
    systemctl enable etcd
    systemctl start etcd
    systemctl restart etcd

注意:192.168.27.212,192.168.27.213部署如同上面步骤,只需要将步骤4里面接点名字、ip改为自己ip即可。
分布式键值高可用存储集群架构搭建(ETCD)
name: etcd2
data-dir: /etc/etcd-v3.3.2/data
listen-client-urls: http://0.0.0.0:2379
advertise-client-urls: http://192.168.27.212:2379
listen-peer-urls: http://0.0.0.0:2380
initial-advertise-peer-urls: http://192.168.27.212:2380
initial-cluster: etcd1=http://192.168.27.211:2380,etcd2=http://192.168.27.212:2380,etcd3=http://192.168.27.213:2380
initial-cluster-token: etcd-cluster-my
initial-cluster-state: new
分布式键值高可用存储集群架构搭建(ETCD)
name: etcd3
data-dir: /etc/etcd-v3.3.2/data
listen-client-urls: http://0.0.0.0:2379
advertise-client-urls: http://192.168.27.213:2379
listen-peer-urls: http://0.0.0.0:2380
initial-advertise-peer-urls: http://192.168.27.213:2380
initial-cluster: etcd1=http://192.168.27.211:2380,etcd2=http://192.168.27.212:2380,etcd3=http://192.168.27.213:2380
initial-cluster-token: etcd-cluster-my
initial-cluster-state: new
6、启动成功后查看集群成员及状态:
[root@client3 etcd-v3.3.2]# etcdctl member list
分布式键值高可用存储集群架构搭建(ETCD)
etcdctl endpoint health --endpoints=192.168.27.211:2379,192.168.27.212:2379,192.168.27.213:2379
分布式键值高可用存储集群架构搭建(ETCD)
[root@client3 etcd-v3.3.2]# etcdctl endpoint status --endpoints=192.168.27.211:2379,192.168.27.212:2379,192.168.27.213:2379
分布式键值高可用存储集群架构搭建(ETCD)
[root@client3 etcd-v3.3.2]# etcdctl endpoint status --endpoints=192.168.27.211:2379
分布式键值高可用存储集群架构搭建(ETCD)
通过非ETCD集群成员访问测试:
[root@master etcd-v3.3.2]# etcdctl endpoint status --endpoints=192.168.27.211:2379
192.168.27.211:2379, f4e909b85dbd820b, 3.3.2, 25 kB, false, 69, 71
[root@master etcd-v3.3.2]# etcdctl endpoint status --endpoints=192.168.27.211:2379
192.168.27.211:2379, f4e909b85dbd820b, 3.3.2, 25 kB, false, 69, 71
[root@master etcd-v3.3.2]# etcdctl endpoint status --endpoints=192.168.27.211:2379,192.168.27.212:2379,192.168.27.213:2379
192.168.27.211:2379, f4e909b85dbd820b, 3.3.2, 25 kB, false, 69, 71
192.168.27.212:2379, 265ebeb3298fa51f, 3.3.2, 25 kB, false, 69, 71
192.168.27.213:2379, 510ff85ed64c7436, 3.3.2, 25 kB, true, 69, 71
[root@master etcd-v3.3.2]# etcdctl put name jerry --endpoints=192.168.27.211:2379,192.168.27.212:2379,192.168.27.213:2379
OK
[root@master etcd-v3.3.2]# etcdctl put topic "this is a etcd client test" --endpoints=192.168.27.211:2379,192.168.27.212:2379,192.168.27.213:2379
OK
[root@master etcd-v3.3.2]# etcdctl get topic --endpoints=192.168.27.211:2379,192.168.27.212:2379,192.168.27.213:2379
topic
this is a etcd client test
[root@master etcd-v3.3.2]# etcdctl get topic --endpoints=192.168.27.211:2379
topic
this is a etcd client test
分布式键值高可用存储集群架构搭建(ETCD)
Etcd使用:
读写键值:
[root@client1 etcd-v3.3.2]# etcdctl put key1 value1
OK
[root@client1 etcd-v3.3.2]# etcdctl get key1
key1
value1
分布式键值高可用存储集群架构搭建(ETCD)
前缀读(将所有前缀是key的键值对都读出来)
分布式键值高可用存储集群架构搭建(ETCD)
键值删除:
[root@client1 etcd-v3.3.2]# etcdctl del key
0
[root@client1 etcd-v3.3.2]# etcdctl get key
[root@client1 etcd-v3.3.2]# etcdctl get key1
key1
value1
[root@client1 etcd-v3.3.2]# etcdctl del key1
1
[root@client1 etcd-v3.3.2]# etcdctl get key1
分布式键值高可用存储集群架构搭建(ETCD)
观察已无KEY1键及值的存在。
分布式键值高可用存储集群架构搭建(ETCD)
按前缀全部删除
分布式键值高可用存储集群架构搭建(ETCD)
观察已无键值及数据
分布式键值高可用存储集群架构搭建(ETCD)
重新创建三个键值:
分布式键值高可用存储集群架构搭建(ETCD)
其它ETCD集群成员上访问键值测试:
分布式键值高可用存储集群架构搭建(ETCD)
监听某个键,每次键值有变化
[root@client1 etcd-v3.3.2]# etcdctl watch key --prefix
PUT
key1
value
PUT
key2
jerry
分布式键值高可用存储集群架构搭建(ETCD)
设置过期时间TTL
分布式键值高可用存储集群架构搭建(ETCD)
分布式键值高可用存储集群架构搭建(ETCD)
[root@client2 etcd-v3.3.2]# etcdctl lease grant 30
lease 251f6cf538287411 granted with TTL(30s)
[root@client2 etcd-v3.3.2]# etcdctl put key5 value5 --lease=251f6cf538287411
Error: etcdserver: requested lease not found
[root@client2 etcd-v3.3.2]# etcdctl lease grant 30
lease 251f6cf538287414 granted with TTL(30s)
[root@client2 etcd-v3.3.2]# etcdctl put key5 value5 --lease=251f6cf538287414
OK
[root@client2 etcd-v3.3.2]# etcdctl lease keep-alive 251f6cf538287414
lease 251f6cf538287414 expired or revoked.
[root@client2 etcd-v3.3.2]# etcdctl get key5
[root@client2 etcd-v3.3.2]# etcdctl get key5
分布式键值高可用存储集群架构搭建(ETCD)
分布式键值高可用存储集群架构搭建(ETCD)
分布式键值高可用存储集群架构搭建(ETCD)

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前标题:分布式键值高可用存储集群架构搭建(ETCD)-创新互联
转载注明:http://csdahua.cn/article/djhodh.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流