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

本示例基於Centos 7,在阿里雲的三臺機器上部署consul集羣,假設目前使用的帳號爲release,擁有sudo權限。html

因爲Docker官方鏡像下載較慢,能夠開啓阿里雲的Docker鏡像下載加速器,可參考此文進行配置。web

假設三臺主機的ip分別爲:docker

  • 主機一:192.168.0.1
  • 主機二:192.168.0.2
  • 主機三:192.168.0.3

三臺主機的安裝步驟類似,以主機一爲例:json

1. 安裝docker服務:bootstrap

 sudo yum install -y docker

 

2. 啓動docker服務: 網絡

sudo service docker start

 

3. 查找consul鏡像:tcp

sudo docker search consul

 

4. 下載官方consul鏡像:ui

sudo  docker pull docker.io/consul

 

5. 下載完後可檢查鏡像:阿里雲

sudo docker images 

 

6. 三臺主機上創建數據目錄和配置目錄,目錄爲空便可:spa

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:對於主機2、三來講,須要加入到這個集羣裏

都啓動完成後,能夠經過以下命令觀察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
相關文章
相關標籤/搜索