主頁 > 知識庫 > 基于Docker的Etcd分布式部署的方法步驟

基于Docker的Etcd分布式部署的方法步驟

熱門標(biāo)簽:申請400電話價格多少 智能電話機(jī)器人坐席 安陽ai電銷機(jī)器人軟件 云會外呼系統(tǒng) 涪陵商都400電話開通辦理 廈門營銷外呼系統(tǒng)平臺 外呼系統(tǒng)的經(jīng)營范圍 柳州市機(jī)器人外呼系統(tǒng)報價 外呼系統(tǒng)不彈窗

一 環(huán)境準(zhǔn)備

1.1 基礎(chǔ)環(huán)境

ntp配置:略 #建議配置ntp服務(wù),保證時間一致性

etcd版本:v3.3.9

防火墻及SELinux:關(guān)閉防火墻和SELinux

名稱
地址
主機(jī)名
備注
etcd1
172.24.8.71
etcd1.example.com
用于保存相關(guān)IP信息
docker01
172.24.8.72
docker01.example.com
 
docker02
172.24.8.73
docker02.example.com
 

# hostnamectl set-hostname etcd1.example.com
# hostnamectl set-hostname docker01.example.com
# hostnamectl set-hostname docker02.example.com

提示:主機(jī)名非必須。

1.2 docker環(huán)境

以上所有節(jié)點均安裝docker,具體方式見《002.docker版本及安裝》。

二 etcd節(jié)點部署

提示:本環(huán)境全部采用docker化,即etcd服務(wù)也以docker形式存在。

2.1 etcd基礎(chǔ)配置

# mkdir -p /var/log/etcd/  #建議創(chuàng)建etcd日志保存目錄
# mkdir -p /data/etcd  #建議創(chuàng)建單獨的etcd數(shù)據(jù)目錄
# export HOST_1=172.24.8.71  #設(shè)置etcd節(jié)點的IP
# export DATA_DIR=/data/etcd  #設(shè)置集群etcd數(shù)據(jù)節(jié)點
# REGISTRY=quay.io/coreos/etcd  #建議使用此倉庫
# ETCD_VERSION=latest  #設(shè)置etcd版本
# export NAME_1=etcd1  #設(shè)置etcd節(jié)點的name
# docker volume create --name etcd-data

提示:以上所有操作需要在所有節(jié)點操作。

2.3 啟動docker etcd集群

[root@etcd1 ~]# docker run \

 -p 2379:2379 \

 -p 2380:2380 \

 --volume=${DATA_DIR}:/etcd-data \

 --name etcd ${REGISTRY}:${ETCD_VERSION} \

 /usr/local/bin/etcd \

 --data-dir=/etcd-data --name ${NAME_1} \

 --initial-advertise-peer-urls http://${HOST_1}:2380 --listen-peer-urls http://0.0.0.0:2380 \

 --advertise-client-urls http://${HOST_1}:2379 --listen-client-urls http://0.0.0.0:2379 \

 --initial-cluster ${NAME_1}=http://${HOST_1}:2380

提示:quay.io/coreos/etcd鏡像國內(nèi)可能無法pull,可在國外節(jié)點pull,然后scp至集群節(jié)點。

2.4 確認(rèn)驗證

 [root@etcd1 ~]# docker ps

 

 [root@etcd1 ~]# docker exec -it bcb96fb0f987 /usr/local/bin/etcdctl cluster-health

[root@etcd1 ~]# docker exec -it bcb96fb0f987 /usr/local/bin/etcdctl --endpoints=http://${HOST_1}:2379 member list

三 docker宿主機(jī)節(jié)點配置

3.1 docker01配置

[root@docker01 ~]# vi /etc/sysconfig/docker
OPTIONS='--cluster-store=etcd://172.24.8.71:2379 --cluster-advertise=172.24.8.72:2379'
[root@docker01 ~]# systemctl restart docker

3.2 docker02配置

[root@docker02 ~]# vi /etc/sysconfig/docker
OPTIONS='--cluster-store=etcd://172.24.8.71:2379 --cluster-advertise=172.24.8.73:2379'
[root@docker02 ~]# systemctl restart docker

3.3 創(chuàng)建overlay網(wǎng)絡(luò)

[root@docker01 ~]# docker network create -d overlay overlaynet1
418654e0092f5d1c3e4bf2b9ee73cdd22932dd60fecf12d7a3b024818118244b
[root@docker01 ~]# docker network inspect overlaynet1

[root@docker02 ~]# docker network inspect overlaynet1

提示:分別在docker01和docker02宿主機(jī)查看在docker01上創(chuàng)建的overlay網(wǎng)絡(luò),若都存在則表示通過 etcd,網(wǎng)絡(luò)數(shù)據(jù)是分布式而不是本地的了。

3.4 測試網(wǎng)絡(luò)

[root@docker01 ~]# docker run -d --name Container01 --network overlaynet1 training/webapp python app.py
[root@docker02 ~]# docker run -d --name Container02 --network overlaynet1 training/webapp python app.py
[root@docker01 ~]# docker exec -it 73e984a5528a /bin/bash
root@73e984a5528a:/opt/webapp# ifconfig

root@73e984a5528a:/opt/webapp# route -n


[root@docker02 ~]# docker exec -it 89eac9521743 /bin/bash
root@89eac9521743:/opt/webapp# ifconfig

說明:

  • 所有容器對會存在兩個網(wǎng)卡,eth0和eth1;
  • 其中 eth1 的網(wǎng)絡(luò)是一個內(nèi)部的網(wǎng)段,即普通的 NAT 模式;
  • 其中 eth0 是 overlay 網(wǎng)段上分配的IP地址,即 overlay 網(wǎng)絡(luò),且 MTU 是 1450 而不是 1500;
  • 只有同一個 overlay 網(wǎng)絡(luò)中的容器之間的通信才會通過 eth0,其它所有通信還是經(jīng)過 eth1。
[root@docker01 ~]# brctl show

[root@docker01 ~]# docker network ls


其他引用:

  • Docker 在每個節(jié)點上創(chuàng)建了兩個 linux bridge,一個用于 overlay 網(wǎng)絡(luò),一個用于非 overlay 的 NAT 網(wǎng)絡(luò)(docker_gwbridge);
  • 容器內(nèi)的到overlay 網(wǎng)絡(luò)的其它容器的網(wǎng)絡(luò)流量走容器的 overlay 網(wǎng)卡(eth0),其它網(wǎng)絡(luò)流量走容器的 NAT 網(wǎng)卡(eth1);
  • 當(dāng)前 Docker 創(chuàng)建 vxlan 隧道的ID范圍為 256~1000,因而最多可以創(chuàng)建745個網(wǎng)絡(luò),因此,本例中的這個 vxlan 隧道使用的 ID 是 256;
  • Docker vxlan 驅(qū)動使用 4789 UDP 端口;
  • overlay網(wǎng)絡(luò)模型底層需要類似 consul 或 etcd 的 KV 存儲系統(tǒng)進(jìn)行消息同步;
  • Docker overlay 不使用多播;
  • Overlay 網(wǎng)絡(luò)中的容器處于一個虛擬的大二層網(wǎng)絡(luò)中,

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:蕪湖 晉城 福州 撫順 孝感 巴中 綏化 南充

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《基于Docker的Etcd分布式部署的方法步驟》,本文關(guān)鍵詞  基于,Docker,的,Etcd,分布式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《基于Docker的Etcd分布式部署的方法步驟》相關(guān)的同類信息!
  • 本頁收集關(guān)于基于Docker的Etcd分布式部署的方法步驟的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章