1. 程式人生 > >Docker應用系列(三)| 構建Consul集群

Docker應用系列(三)| 構建Consul集群

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集群