kuberntes 系统使用 etcd 存储所有数据,本文档介绍部署一个三节点高可用 etcd 集群的步骤,这三个节点配置复用 ,我在这里没有做认证,如果有需要也可以做。

下载二进制文件

https://github.com/coreos/etcd/releases 页面下载最新版本的二进制文件

# wget https://github.com/etcd-io/etcd/releases/download/v3.2.24/etcd-v3.2.24-linux-amd64.tar.gz

# tar –xvf etcd-v3.2.24-linux-amd64.tar.gz

# mv etcd-v3.2.24-linux-amd64/* /usr/local/bin/

**********************************************************

这里也可以用yum方式安装

# yum install etcd –y
 
yum 安装的 Etcd 默认配置文件在 /etc/etcd/etcd.conf具体配置内容,以下*.*.*.*根据自己实际ip地址。
 
# 编辑配置文件 vim /etc/etcd/etcd.conf 
# 样例配置如下 
# 节点名称 ETCD_NAME=etcd0 
# 数据存放位置 ETCD_DATA_DIR="/var/lib/etcd/etcd0" 
# 监听其他 Etcd 实例的地址 ETCD_LISTEN_PEER_URLS="http://0.0.0.0:2380" 
# 监听客户端地址 ETCD_LISTEN_CLIENT_URLS="http://0.0.0.0:2379,http://0.0.0.0:4001" 
# 通知其他 Etcd 实例地址 ETCD_INITIAL_ADVERTISE_PEER_URLS="http://*.*.*.*:2380" 
# 初始化集群内节点地址 ETCD_INITIAL_CLUSTER="etcd0=http://*.*.*.*:2380,etcd1=http://*.*.*.*:2380,etcd2=http://*.*.*.*:2380" 
# 初始化集群状态,new 表示新建 ETCD_INITIAL_CLUSTER_STATE="new" 
# 初始化集群 token ETCD_INITIAL_CLUSTER_TOKEN="mritd-etcd-cluster" 
# 通知 客户端地址 ETCD_ADVERTISE_CLIENT_URLS="http://*.*.*.*:2379,http://*.*.*.*:4001"
 
************************************************************
 
在/usr/lib/systemd/system/目录下创建文件etcd.service,内容如下
 

[Unit]

Description=Etcd Server

After=network.target

After=network-online.target

Wants=network-online.target

Documentation=https://github.com/coreos

[Service]

Type=notify

WorkingDirectory=/var/lib/etcd/

EnvironmentFile=-/etc/etcd/etcd.conf

ExecStart=/usr/local/bin/etcd \
   --name ${ETCD_NAME} \
   --initial-advertise-peer-urls ${ETCD_INITIAL_ADVERTISE_PEER_URLS} \
   --listen-peer-urls ${ETCD_LISTEN_PEER_URLS} \
   --listen-client-urls ${ETCD_LISTEN_CLIENT_URLS},http://127.0.0.1:2379 \
   --advertise-client-urls ${ETCD_ADVERTISE_CLIENT_URLS} \
   --initial-cluster-token ${ETCD_INITIAL_CLUSTER_TOKEN} \
   --initial-cluster etcd1=http://172.16.*.*:2380,etcd2=http://172.16.*.*:2380,etcd3=http://172.16.*.*:2380 \
   --initial-cluster-state new \
   --data-dir=${ETCD_DATA_DIR}

Restart=on-failure

RestartSec=5

LimitNOFILE=65536

[Install]

WantedBy=multi-user.target

环境变量配置文件/etc/etcd/etcd.conf

# [member]

ETCD_NAME=etcd1

ETCD_DATA_DIR="/var/lib/etcd"

ETCD_LISTEN_PEER_URLS=http://172.16.*.*:2380

ETCD_LISTEN_CLIENT_URLS=http://172.16.*.*:2379

#[cluster]

ETCD_INITIAL_ADVERTISE_PEER_URLS=http://172.16.*.*:2380

ETCD_INITIAL_CLUSTER_TOKEN="etcd-cluster"

ETCD_ADVERTISE_CLIENT_URLS=http://172.16.*.*:2379

启动etcd集群(这里的启动先启动etcd2和etcd3,最后启动etcd1)

systemctl daemon-reload
systemctl enable etcd
systemctl start etcd
systemctl status etcd
 
验证etcd集群是否正常

etcdctl cluster-health

member 295f11ee2eb4860f is healthy: got healthy result from http://172.16.*.*:2379

member 52e09c7ccb0e79aa is healthy: got healthy result from http://172.16.*.*:2379

member 58804fbff8cfcce0 is healthy: got healthy result from http://172.16.*.*:2379

cluster is healthy

etcdctl member list

295f11ee2eb4860f: name=etcd3 peerURLs=http://172.16.*.*:2380 clientURLs=http://172.16.*.*:2379 isLeader=false

52e09c7ccb0e79aa: name=etcd1 peerURLs=http://172.16.*.*:2380 clientURLs=http://172.16.*.*:2379 isLeader=false

58804fbff8cfcce0: name=etcd2 peerURLs=http://172.16.*.*:2380 clientURLs=http://172.16.*.*:2379 isLeader=true

可以看到etcd集群正常在etcd2上运行,可以停止etcd2查看etcd是否跳到别的机器上,具体自己测试一下就不过多说明

最新文章

  1. PHP-- 三种数据库随机查询语句写法
  2. Deep Learning 3_深度学习UFLDL教程:预处理之主成分分析与白化_总结(斯坦福大学深度学习教程)
  3. layoutSubviews,setNeedsDisplay
  4. MATLAB 函数
  5. Jenkins+Maven+SVN搭建自动部署、自动测试环境
  6. Thread: BooleanRT : Realtime 3D boolean operations for (Runtime,Editor)
  7. sae crop 文档
  8. JAVA编程相关:eclipse如何导入已有工程
  9. HR筒子说:程序猿面试那点事
  10. Redux管理你的React应用
  11. 配置日志logwarch 每天发送到邮箱
  12. Angular-Mobile介绍
  13. SpringBoot------拦截器Filter的使用
  14. HDU 4436 str2int (后缀自动机SAM,多串建立)
  15. python unittest 1
  16. 1000多块整个插板,arduino + android 蓝牙插板的实现--屌丝版
  17. Python之numpy基本指令
  18. css字体中px和em的区别
  19. 如何查看非自己提交的请求的结果 - 深入浅出Oracle EBS之杂项技术荟萃
  20. 仿淘宝商品详情页上拉弹出新ViewController

热门文章

  1. IO流之转换流
  2. vue+axios+easy-mock+element-ui实现表格分页功能
  3. Ckrule业务规则管理系统简介
  4. matlab练习程序(Arnold图像置乱)
  5. Dll注入:修改PE文件 IAT注入
  6. NO.001-2018.02.06《木兰花·拟古决绝词柬友》清代:纳兰性德
  7. 【洛谷2290】[HNOI2004] 树的计数(Python+利用prufer序列结论求解)
  8. jmeter报"msg":"Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported"的解决方法
  9. Oracle文本导入器
  10. SpringBoot 使用(三): 配置文件详解