一 環境準備
1.1 基礎環境
ntp配置:略 #建議配置ntp服務,保證時間一致性
etcd版本:v3.3.9
防火墻及SELinux:關閉防火墻和SELinux
名稱 | 地址 | 主機名 | 備注 |
etcd1 | 172.24.8.71 | etcd1.example.com | 用于保存相關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
提示:主機名非必須。
1.2 docker環境
以上所有節點均安裝docker,具體方式見《002.docker版本及安裝》。
二 etcd節點部署
提示:本環境全部采用docker化,即etcd服務也以docker形式存在。
2.1 etcd基礎配置
# mkdir -p /var/log/etcd/ #建議創建etcd日志保存目錄# mkdir -p /data/etcd #建議創建單獨的etcd數據目錄# export HOST_1=172.24.8.71 #設置etcd節點的IP# export DATA_DIR=/data/etcd #設置集群etcd數據節點# REGISTRY=quay.io/coreos/etcd #建議使用此倉庫# ETCD_VERSION=latest #設置etcd版本# export NAME_1=etcd1 #設置etcd節點的name# docker volume create --name etcd-data
提示:以上所有操作需要在所有節點操作。
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鏡像國內可能無法pull,可在國外節點pull,然后scp至集群節點。
2.4 確認驗證
[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宿主機節點配置
3.1 docker01配置
[root@docker01 ~]# vi /etc/sysconfig/dockerOPTIONS='--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/dockerOPTIONS='--cluster-store=etcd://172.24.8.71:2379 --cluster-advertise=172.24.8.73:2379'[root@docker02 ~]# systemctl restart docker
3.3 創建overlay網絡
[root@docker01 ~]# docker network create -d overlay overlaynet1418654e0092f5d1c3e4bf2b9ee73cdd22932dd60fecf12d7a3b024818118244b[root@docker01 ~]# docker network inspect overlaynet1
[root@docker02 ~]# docker network inspect overlaynet1
提示:分別在docker01和docker02宿主機查看在docker01上創建的overlay網絡,若都存在則表示通過 etcd,網絡數據是分布式而不是本地的了。
3.4 測試網絡
[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/bashroot@73e984a5528a:/opt/webapp# ifconfig
root@73e984a5528a:/opt/webapp# route -n
[root@docker02 ~]# docker exec -it 89eac9521743 /bin/bashroot@89eac9521743:/opt/webapp# ifconfig
說明:
[root@docker01 ~]# brctl show
[root@docker01 ~]# docker network ls
其他引用:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答
圖片精選