一 介绍

etcd 高可用一致性键值存储系统,使用Raft一直算法处理日志复制以保证数据一致性。主要在搭建kubernates时关注到etcd来研究部署etcd。使用golang语言编写,和zookeeper一样可用用于服务注册发现,以及配置管理等。github地址:https://github.com/coreos/etcd

二 单点部署

1. 使用 git,wget 下载源码

2. cd etcd-master

3. etcd 启动

4. 测试

使用 etcdctrl 测试

以上通过单点部署etcd 以及测试体验etcd作为键值存储所做的工作。

三 实现etcd集群的部署

1. 部署环境

为了方便部署过程只在通过IP指定无需修改host文件指定hostname。

只在一台机器搭建集群通过端口地址不同来区别。

      192.168.100.128:2381

      192.168.100.128:2382

      192.168.100.128:2383

  github 集群搭建地址:https://github.com/coreos/etcd/blob/master/Documentation/op-guide/clustering.md#etcd-discovery

2. 启动

node1:

        etcd --name infra0 --initial-advertise-peer-urls http://192.168.100.128:2381 \

  --listen-peer-urls http://192.168.100.128:2381 \
--listen-client-urls http://192.168.100.128:2279,http://127.0.0.1:2279 \
--advertise-client-urls http://192.168.100.128:2279 \
--initial-cluster-token etcd-cluster-1 \
--initial-cluster infra0=http://192.168.100.128:2381,infra1=http://192.168.100.128:2382,infra2=http://192.168.100.128:2383 \
--initial-cluster-state new

node2:

  etcd --name infra1 --initial-advertise-peer-urls http://192.168.100.128:2382 \

  --listen-peer-urls http://192.168.100.128:2382 \
--listen-client-urls http://192.168.100.128:2280,http://127.0.0.1:2280 \
--advertise-client-urls http://192.168.100.128:2280 \
--initial-cluster-token etcd-cluster-1 \
--initial-cluster infra0=http://192.168.100.128:2381,infra1=http://192.168.100.128:2382,infra2=http://192.168.100.128:2383 \
--initial-cluster-state new
node3:

  etcd --name infra2 --initial-advertise-peer-urls http://192.168.100.128:2383 \

  --listen-peer-urls http://192.168.100.128:2383 \
--listen-client-urls http://192.168.100.128:2281,http://127.0.0.1:2281 \
--advertise-client-urls http://192.168.100.128:2281 \
--initial-cluster-token etcd-cluster-1 \
--initial-cluster infra0=http://192.168.100.128:2381,infra1=http://192.168.100.128:2382,infra2=http://192.168.100.128:2383 \
--initial-cluster-state new
3 效果图



四 描述
另外文档还给出了TLS ca证书安装部署方式,以及自动自动证书安装 部署方式,以及使用DNS启动部署。
五 docker 环境 etcd 启动
在github中有Dockerfile文件可以构建镜像然后根据所需搭建etcd集群容器。
六 总结
etcd 和 zookeeper一样解决了数据一致性以及通过自动选举算法实现解决容灾问题,保证数据的高可用性以及强一致性。我们可以用etcd做服务注册发现以及配置管理等。当也可以当作key,vlue存储键值数据。
研究部署etcd主要是为了搭建kubernates服务,因为kubernates系统资源调度使用etcd做服务注册发现。

搭建etcd集群的更多相关文章

  1. Docker 搭建 etcd 集群

    阅读目录: 主机安装 集群搭建 API 操作 API 说明和 etcdctl 命令说明 etcd 是 CoreOS 团队发起的一个开源项目(Go 语言,其实很多这类项目都是 Go 语言实现的,只能说很 ...

  2. docker搭建etcd集群环境

    其实关于集群网上说的方案已经很多了,尤其是官网,只是这里我个人只有一个虚拟机,在开发环境下建议用docker-compose来搭建etcd集群. 1.拉取etcd镜像 docker pull quay ...

  3. 【转】centos7 搭建etcd集群

    转自http://www.cnblogs.com/zhenyuyaodidiao/p/6237019.html 一.简介 “A highly-available key value store for ...

  4. 二进制搭建kubernetes多master集群【一、使用TLS证书搭建etcd集群】

    上一篇我们介绍了kubernetes集群架构以及系统参数配置,参考:二进制搭建kubernetes多master集群[开篇.集群环境和功能介绍] 下面本文etcd集群才用三台centos7.5搭建完成 ...

  5. Docker 搭建 etcd 集群及管理

    环境 host1 10.1.99.13 host2 10.1.99.14 host3 10.1.99.15 host4 10.1.99.12(用于测试添加删除节点) 初始化集群 host1 $ doc ...

  6. Docker 搭建 etcd 集群配置

    #关闭selinux.防火墙 systemctl stop firewalld.service systemctl disable firewalld.service firewall-cmd --s ...

  7. 多主机搭建etcd集群

    下载https://github.com/etcd-io/etcd/releases/download/v3.4.10/etcd-v3.4.10-linux-amd64.tar.gz分别放到两台主机上 ...

  8. 基于已有集群动态发现方式部署 Etcd 集群

    etcd提供了多种部署集群的方式,在「通过静态发现方式部署etcd集群」 一文中我们介绍了如何通过静态发现方式部署集群. 不过很多时候,你只知道你要搭建一个多大(包含多少节点)的集群,但是并不能事先知 ...

  9. 基于 DNS 动态发现方式部署 Etcd 集群

    使用discovery的方式来搭建etcd集群方式有两种:etcd discovery和DNS discovery.在 「基于已有集群动态发现方式部署etcd集群」一文中讲解了etcd discove ...

随机推荐

  1. Jmeter(七)Mongodb的增删改查

    1.启动JMeter,新建线程组,设置线程组属性 2.右键添加-MongoDB Source Config 设置属性Server Address List:192.168.0.99 MongoDB S ...

  2. windows平台tensorboard的配置及使用

    由于官网和其他教程里面都是以Linux为平台演示tensorboard使用的,而在Windows上与Linux上会有一些差别,因此我将学习的过程记录下来与大家分享(基于tensorflow1.2.1版 ...

  3. 利用crontab系统每天定时备份MySQL数据库及删除指定crontab定时任务

    利用系统crontab来定时执行备份文件,按日期对备份结果进行保存,达到备份的目的. 1.创建保存备份文件的路径/mysqldata mkdir /mysqldata 2.创建/usr/sbin/ba ...

  4. PAT 1041 Be Unique[简单]

    1041 Be Unique (20 分) Being unique is so important to people on Mars that even their lottery is desi ...

  5. 怎么创建Porlet项目

    首先找到你liferay安装的地址D:\liferay\liferay-bundles-6.1.1\plugins-sdk,找到portlets这个文件夹点击(shift+鼠标右键)进入命令行窗口,写 ...

  6. C# 使用 SqlBulkCopy 类批量复制数据到数据库

    最近公司需要优化导入的问题,由于之前使用的方式是生成 Insert 语句插入数据库,数据量小的时候还行,但是随着发展数据量渐渐大了,之前的方法性能就跟不上了,于是发现了 SqlBulkCopy 这个类 ...

  7. XSS是什么

    1.XSS是跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS. 2.恶意攻击 ...

  8. c++之旅:继承

    继承 继承有关于权限的继承,多继承和虚继承 权限继承 权限继承有公有继承,保护继承和私有继承 公有继承 公有继承可以继承父类的public和protected属性和方法 #include <io ...

  9. 字符编码的发展(ASCII、Unicode、utf-8)

    最近一直在看廖雪峰老师的python网上教程,python内容简单易理解,就没整理,但是字符串编码作为一直困扰自己的问题,看了几遍文章,最终还是将其整理如下,本篇博客总结自廖雪峰老师的网上教程:htt ...

  10. LookupEdit已选过后如何删除值使其空白

    属性Properties 的AllowNullInput 设置为True,就可以删除了. 当选择值后,按下control+delete就可以变为空白