etcd集群安装部署
1. 集群架构

由于我们只有两个机房,所以选择的是以上图中所示的数据同步方案, 通过做镜像的方式保证两个集群的数据实时同步。
整体架构如上图所示, 整个全局元数据中心包括两套集群,廊坊集群和马驹桥集群; 同时服务的只会有一个集群, 两个集群通过mirror-maker实时同步元数据,保证元数据无差别。
正常访问流程如下:
用户=》 OPS域名 =》 域名解析到廊坊 =》 通过负载均衡路由廊坊机房的4001端口 =》 访问数据返回
以上描述了一次正常的请求; 整体架构比较简单,主要是因为ETCD集群无法部署在三个机房(没有资源);所以选择了通过但机房部署,多机房数据同步的方案进行实时数据备份;
2. 灾备方案
(1). 通过mirror-maker实时做镜像的方式同步数据,如果出现主机房服务挂了可以通过切换域名的形式切换到灾备机房;这个过程中数据是可以保持一致的。
(2). etcd集群的数据每隔半个小时会备份一次数据, 备份的数据会直接上传到云存储上,一旦系统出现问题可以随时通过备份数据进行故障恢复;保证业务的可用性
3. 安装流程
a. 通过官网说明下载最新的ETCD程序
https://github.com/coreos/etcd/releases
可以参考以下脚本,下载并且解压
#!/bin/bash
ETCD_VER=v3.3.5
GITHUB_URL=https://github.com/coreos/etcd/releases/download
DOWNLOAD_URL=${GITHUB_URL}
rm -f /tmp/etcd-${ETCD_VER}-linux-amd64.tar.gz
rm -rf /tmp/etcd-download-test && mkdir -p /tmp/etcd-download-test curl -L ${DOWNLOAD_URL}/${ETCD_VER}/etcd-${ETCD_VER}-linux-amd64.tar.gz -o /tmp/etcd-${ETCD_VER}-linux-amd64.tar.gz
tar xzvf /tmp/etcd-${ETCD_VER}-linux-amd64.tar.gz -C /tmp/etcd-download-test --strip-components=
b. 校验版本
通过执行以下命令教研ETCD版本是否和是我们下载的版本
#校验etcd版本
$/tmp/etcd-download-test/etcd --version
etcd Version: 3.3.5
Git SHA: cb2a496
Go Version: go1.8.3
Go OS/Arch: linux/amd64 #校验etcdctl版本
$ETCDCTL_API= /tmp/etcd-download-test/etcdctl version
etcdctl version: 3.3.5
API version: 3.2
c. ETCD启动
通过以上步骤校验完版本之后就可以开始整理命令行参数启动etcd了;
这里我们直接使用ETCD配置文件配置相应的集群信息,ETCD配置文件如下:
vim /etc/etcd/etcd.conf
192.168.186.95 配置
ETCD_NAME=etcd95
ETCD_DATA_DIR="/export/Data/etcd/etcd95"
ETCD_STRICT_RECONFIG_CHECK=true
ETCD_ADVERTISE_CLIENT_URLS="http://192.168.186.95:4001"
ETCD_INITIAL_ADVERTISE_PEER_URLS="http://192.168.186.95:7001"
ETCD_LISTEN_CLIENT_URLS="http://192.168.186.95:4001"
ETCD_LISTEN_PEER_URLS="http://192.168.186.95:7001"
ETCD_INITIAL_CLUSTER_STATE="new"
ETCD_INITIAL_CLUSTER_TOKEN="etcd-global-cluster"
ETCD_INITIAL_CLUSTER="etcd95=http://192.168.186.95:7001,etcd53=http://192.168.186.53:7001,etcd73=http://192.168.186.73:7001"
192.168.186.53 配置
ETCD_NAME=etcd53
ETCD_DATA_DIR="/export/Data/etcd/etcd53"
ETCD_STRICT_RECONFIG_CHECK=true
ETCD_ADVERTISE_CLIENT_URLS="http://192.168.186.53:4001"
ETCD_INITIAL_ADVERTISE_PEER_URLS="http://192.168.186.53:7001"
ETCD_LISTEN_CLIENT_URLS="http://192.168.186.53:4001"
ETCD_LISTEN_PEER_URLS="http://192.168.186.53:7001"
ETCD_INITIAL_CLUSTER_STATE="new"
ETCD_INITIAL_CLUSTER_TOKEN="etcd-global-cluster"
ETCD_INITIAL_CLUSTER="etcd95=http://192.168.186.95:7001,etcd53=http://192.168.186.53:7001,etcd73=http://192.168.186.73:7001"
192.168.186.73 配置
ETCD_NAME=etcd73
ETCD_DATA_DIR="/export/Data/etcd/etcd73"
ETCD_STRICT_RECONFIG_CHECK=true
ETCD_ADVERTISE_CLIENT_URLS="http://192.168.186.73:4001"
ETCD_INITIAL_ADVERTISE_PEER_URLS="http://192.168.186.73:7001"
ETCD_LISTEN_CLIENT_URLS="http://192.168.186.73:4001"
ETCD_LISTEN_PEER_URLS="http://192.168.186.73:7001"
ETCD_INITIAL_CLUSTER_STATE="new"
ETCD_INITIAL_CLUSTER_TOKEN="etcd-global-cluster"
ETCD_INITIAL_CLUSTER="etcd95=http://192.168.186.95:7001,etcd53=http://192.168.186.53:7001,etcd73=http://192.168.186.73:7001"
d. 设置守护进程
配置每台机器的环境变量配置文件之后,需要设置守护进程;
vim /usr/lib/systemd/system/etcd.service
[Unit]
Description=etcd key-value store
Documentation=https://github.com/coreos/etcd
After=network.target
[Service]
User=etcd
Type=notify
#这个文件特别关键,etcd使用的环境变量都需要通过环境变量文件读取
EnvironmentFile=/etc/etcd/etcd.conf
ExecStart=/usr/bin/etcd --auto-compaction-retention '' --max-request-bytes '' --quota-backend-bytes ''
Restart=always
RestartSec=10s
LimitNOFILE=
[Install]
WantedBy=multi-user.target
e. 注意事项
一定需要确认数据目录对用户etcd有读写权限,否则服务可能无法正确启动
f. 启动
#启动前先创建软连接
ln -s /export/App/etcd-v3.2.2/etcd /usr/bin/etcd #执行以下命令启动etcd
systemctl daemon-reload
systemctl start etcd
systemctl enable etcd
g.状态校验
#启动完成之后需要进行状态校验
./etcdctl --endpoints="http://192.168.186.95:4001,http://192.168.186.53:4001,http://192.168.186.73:4001" member list
./etcdctl --endpoints="http://192.168.186.95:4001,http://192.168.186.53:4001,http://192.168.186.73:4001" cluster-health 返回信息如下:
4b68b919da5a093d: name=etcd95 peerURLs=http://192.168.186.95:7001 clientURLs=http://192.168.186.95:4001 isLeader=true
93fed96717b4821c: name=etcd53 peerURLs=http://192.168.186.53:7001 clientURLs=http://192.168.186.53:4001 isLeader=false
ed0bc855ed0b5faf: name=etcd73 peerURLs=http://192.168.186.73:7001 clientURLs=http://192.168.186.73:4001 isLeader=false member 4b68b919da5a093d is healthy: got healthy result from http://192.168.186.95:4001
member 93fed96717b4821c is healthy: got healthy result from http://192.168.186.53:4001
member ed0bc855ed0b5faf is healthy: got healthy result from http://192.168.186.73:4001
etcd集群安装部署的更多相关文章
- K8S集群安装部署
K8S集群安装部署 参考地址:https://www.cnblogs.com/xkops/p/6169034.html 1. 确保系统已经安装epel-release源 # yum -y inst ...
- HBase集群安装部署
0x01 软件环境 OS: CentOS6.5 x64 java: jdk1.8.0_111 hadoop: hadoop-2.5.2 hbase: hbase-0.98.24 0x02 集群概况 I ...
- flink部署操作-flink standalone集群安装部署
flink集群安装部署 standalone集群模式 必须依赖 必须的软件 JAVA_HOME配置 flink安装 配置flink 启动flink 添加Jobmanager/taskmanager 实 ...
- HBase 1.2.6 完全分布式集群安装部署详细过程
Apache HBase 是一个高可靠性.高性能.面向列.可伸缩的分布式存储系统,是NoSQL数据库,基于Google Bigtable思想的开源实现,可在廉价的PC Server上搭建大规模结构化存 ...
- 1.Hadoop集群安装部署
Hadoop集群安装部署 1.介绍 (1)架构模型 (2)使用工具 VMWARE cenos7 Xshell Xftp jdk-8u91-linux-x64.rpm hadoop-2.7.3.tar. ...
- 2 Hadoop集群安装部署准备
2 Hadoop集群安装部署准备 集群安装前需要考虑的几点硬件选型--CPU.内存.磁盘.网卡等--什么配置?需要多少? 网络规划--1 GB? 10 GB?--网络拓扑? 操作系统选型及基础环境-- ...
- 【分布式】Zookeeper伪集群安装部署
zookeeper:伪集群安装部署 只有一台linux主机,但却想要模拟搭建一套zookeeper集群的环境.可以使用伪集群模式来搭建.伪集群模式本质上就是在一个linux操作系统里面启动多个zook ...
- 第06讲:Flink 集群安装部署和 HA 配置
Flink系列文章 第01讲:Flink 的应用场景和架构模型 第02讲:Flink 入门程序 WordCount 和 SQL 实现 第03讲:Flink 的编程模型与其他框架比较 第04讲:Flin ...
- etcd简介及集群安装部署使用
目录 1. 简介 2. Linux下载安装 3. 单机模式启动 4. 指定各集群成员的方式配置集群 5. 使用discovery service的方式配置集群 6. 集群模式下客户端命令行 7. et ...
随机推荐
- unity, 不要试图用rigidbody.Sleep()停止rigidbody
如果想让rigidbody pause,用rigidbody.Sleep()是完全错误的办法.因为有很多情况都可能使一个处在sleep的rigidbody唤醒,所以调用rigidbody.Sleep( ...
- 《MVC +EasyUI 》——表单的提交
之前用AJax给Controller传递參数,然后再调用服务端的方法对数据库进行更改,今天碰到一个新的方法,就是表单的提交.这样能够省去AJax穿參.当表单提交后.我们能够获取表单上控件中的值 ...
- atitit.userService 用户系统设计 v6 q413
atitit.userService 用户系统设计 v6 q413 1. 新特性1 2. Admin login1 3. 用户注册登录2 3.1. <!-- 会员注册使用 --> 商家 ...
- Atitit. 脚本语言的断点单步调试的设计与实现 attialx 总结 php 参照java
Atitit. 脚本语言的断点单步调试的设计与实现 attialx 总结 php 参照java 1. 断点的实现:手动断点 die和exit是等价的 1 2. 变量表的实现 1 3. print_r( ...
- atitit.eclipse有多少api 扩展点,以及扩展点的设计
atitit.eclipse有多少api 扩展点,以及扩展点的设计 不赞成使用的.作废的以及内部的扩展点 [扩展]页显示了几个你不应该在你的插件中使用的扩展点.在附表C.1的[描述]栏中,我们使用如 ...
- [转载]mac下查看.mobileprovision文件及钥匙串中证书.cer文件
一. mobileprovision文件查看 xxx.mobileprovision是ios开发中的设备描述文件,里面有证书信息.调试设备的UUID信息.bundle identifier等,此文件是 ...
- CCNA2.0笔记_OSPF v2
OSPF(开放最短路径优先)协议概述: - 链路状态路由协议 - 无类路由协议 - 要点:RouterID.区域ID - 触发更新 .以传播 LSA 代替路由表更新 - 快速响应变更(比距离矢量路由协 ...
- JavaScript变量的生命周期
最近看国外经典教材的时候发现JavaScript与熟知的Java,C,C++都不同的特性,其中一个就是变量的生命周期. 1.在JavaScript中,对于for循环中定义的i变量,其生命周期在循环 ...
- go context包的WithTimeout和WithCancel的使用
1.WaitGroup 它是一种控制并发的方式,它的这种方式是控制多个goroutine同时完成. func main() { var wg sync.WaitGroup wg.Add(2) go f ...
- 如何编写Makefile?
//swap.c #include<stdio.h> int swap(int *x,int *y) {printf("a=%d b=%d\n",*x,*y); int ...