Docker應用系列(三)| 構建Consul集群
阿新 • • 發佈:2018-09-18
pull run target expec ear cnblogs http 權限 信息
本示例基於Centos 7,在阿裏雲的三臺機器上部署consul集群,假設目前使用的賬號為release,擁有sudo權限。
由於Docker官方鏡像下載較慢,可以開啟阿裏雲的Docker鏡像下載加速器,可參考此文進行配置。
假設三臺主機的ip分別為:
- 主機一:192.168.0.1
- 主機二:192.168.0.2
- 主機三:192.168.0.3
三臺主機的安裝步驟相似,以主機一為例:
1. 安裝docker服務:
sudo yum install -y docker
2. 啟動docker服務:
sudo service docker start
3. 查找consul鏡像:
sudo docker search consul
4. 下載官方consul鏡像:
sudo docker pull docker.io/consul
5. 下載完後可檢查鏡像:
sudo docker images
6. 三臺主機上建立數據目錄和配置目錄,目錄為空即可:
mkdir -p /data/consul_data/data
mkdir -p /data/consul_data/conf
7. 三臺主機依次啟動容器:
主機一的命令為:
sudo docker run --net=host --name consul -v /data/consul_data/data:/consul/data -v /data/consul_data/conf:/consul/config -d docker.io/consul consul agent -server -bind=192.168.0.1 -bootstrap-expect=3 -data-dir /consul/data -config-dir /consul/config
主機二的命令為:
sudo docker run --net=host --name consul -v /data/consul_data/data:/consul/data -v /data/consul_data/conf:/consul/config -d docker.io/consul consul agent -server -bind=192.168.0.1 -bootstrap-expect=3 -data-dir /consul/data -config-dir/consul/config -join 192.168.0.1
主機三的命令為:
sudo docker run --net=host --name consul -v /data/consul_data/data:/consul/data -v /data/consul_data/conf:/consul/config -d docker.io/consul consul agent -server -bind=192.168.0.3 -bootstrap-expect=3 -data-dir /consul/data -config-dir /consul/config -join 192.168.0.1
命令說明:
- --net=host:采用主機網絡配置,若采用默認的bridge模式,則會存在容器跨主機間通信失敗的問題
- -v /data/consul_data/data:/consul/data:主機的數據目錄掛載到容器的/consul/data下,因為該容器默認的數據寫入位置即是/consul/data
- -v /data/consul_data/conf:/consul/config:主機的配置目錄掛載到容器的/consul/conf下,因為該容器默認的數據寫入位置即是/consul/conf
- consul agent -server:consul的server啟動模式
- consul agent -bind=192.168.0.3:consul綁定到主機的ip上
- consul agent -bootstrap-expect=3:server要想啟動,需要至少3個server
- consul agent -data-dir /consul/data:consul的數據目錄
- consul agent -config-dir /consul/config:consul的配置目錄
- consul agent -join 192.168.0.1:對於主機二、三來說,需要加入到這個集群裏
都啟動完成後,可以通過如下命令觀察consul日誌,了解啟動情況:
sudo docker logs 容器id/容器名稱
日誌情況示例如下:
[release@sh-lbs02 data]$ sudo docker logs consul [sudo] password for release: bootstrap_expect > 0: expecting 3 servers ==> Starting Consul agent... ==> Joining cluster... Join completed. Synced with 1 initial agents ==> Consul agent running! Version: ‘v1.2.3‘ Node ID: ‘56e5b37e-b636-3cfa-6a9b-2ce47e0dfbd1‘ Node name: ‘sh-lbs02‘ Datacenter: ‘dc1‘ (Segment: ‘<all>‘) Server: true (Bootstrap: false) Client Addr: [127.0.0.1] (HTTP: 8500, HTTPS: -1, DNS: 8600) Cluster Addr: 192.168.0.1 (LAN: 8301, WAN: 8302) Encrypt: Gossip: false, TLS-Outgoing: false, TLS-Incoming: false
8. 檢查集群狀態:
sudo docker exec -it 容器id /bin/sh
通過該命令進入容器,查看集群信息:
[release@sh-lbs02 data]$ sudo docker exec -it 8a /bin/sh / # consul members Node Address Status Type Build Protocol DC Segment lbs02 192.168.0.1:8301 alive server 1.2.3 2 dc1 <all> web01 192.168.0.2:8301 alive server 1.2.3 2 dc1 <all> web02 192.168.0.3:8301 alive server 1.2.3 2 dc1 <all> / #
至此,集群已啟動完成,consul的端口打開較多,可以在主機上觀察其端口情況:
[release@sh-web02 ~]$ sudo netstat -tlnp|grep consul [sudo] password for release: tcp 0 0 192.168.0.1:8300 0.0.0.0:* LISTEN 330/consul tcp 0 0 192.168.0.1:8301 0.0.0.0:* LISTEN 330/consul tcp 0 0 192.168.0.1:8302 0.0.0.0:* LISTEN 330/consul tcp 0 0 127.0.0.1:8500 0.0.0.0:* LISTEN 330/consul tcp 0 0 127.0.0.1:8600 0.0.0.0:* LISTEN 330/consul
9. 如何啟動consul客戶端?假設consul客戶端與服務端在同一個主機上:
首先,建立客戶端的配置目錄和數據目錄:
mkdir -p /data/consul_data_cli/data mkdir -p /data/consul_data_cli/conf
其次,在配置目錄下分配客戶端使用的端口,避免與服務端的端口沖突:
cd /data/consul_data_cli/conf touch basic.json vi basic.json #內容如下: { "ports": { "http":18501, "dns":18601, "rpc":18401, "serf_lan":18301, "serf_wan":18302, "server":18300 } }
最後,啟動客戶端:
sudo docker run --net=host --name consul-cli -v /data/consul_data_cli/data:/consul/data -v /data/consul_data_cli/conf:/consul/config -d docker.io/consul consul agent -bind=192.168.0.2 -data-dir /consul/data -config-dir /consul/config -join 192.168.0.1:8301
Docker應用系列(三)| 構建Consul集群