本示例基於Centos 7,在阿里雲的三臺機器上部署consul集羣,假設目前使用的帳號爲release,擁有sudo權限。html
因爲Docker官方鏡像下載較慢,能夠開啓阿里雲的Docker鏡像下載加速器,可參考此文進行配置。web
假設三臺主機的ip分別爲:docker
三臺主機的安裝步驟類似,以主機一爲例: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
命令說明:
都啓動完成後,能夠經過以下命令觀察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