溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Docker Compose 容器編排 + Consul 集

發(fā)布時間:2020-02-28 03:59:20 來源:網(wǎng)絡(luò) 閱讀:320 作者:wx5d3faba330584 欄目:云計算

一、Docker Compose 容器編排

1、Docker Compose 前身是Fig,是一個定義及運行多個 Docker 容器的工具;
2、使用 Docker Compose 不再需要使用 shell腳本來啟動容器;
3、Docker Compose 非常適合組合使用多個容器進行開發(fā)的場景。
4、Docker Compose 的文件結(jié)構(gòu):

-----vim docker-compose.yml

YAML 是一種標記語言很直觀的數(shù)據(jù)序列化格式
以下是文件格式及編寫注意事項:
Docker Compose 容器編排 + Consul 集

二、Docker Compose 配置:

(1)常用字段:
Docker Compose 容器編排 + Consul 集
(2)常用命令:
Docker Compose 容器編排 + Consul 集
(3) Compose 命令說明:
Docker Compose 容器編排 + Consul 集
Docker Compose 容器編排 + Consul 集

二、編排實例:

(1)先優(yōu)化好網(wǎng)絡(luò):

vim /etc/sysctl.conf
net.ipv4.ip_forward=1    ##文件末尾加入

sysctl -p                  ##修改生效
systemctl restart network  ##重啟網(wǎng)絡(luò)服務(wù)

(2)將下載好的 docker-compose 復(fù)制到 /usr/bin/ 目錄下:

cp  -p  docker-compose  /usr/bin/

(3)創(chuàng)建工作目錄(將nginx軟件包拷貝到nginx目錄下):

[root@localhost ~]# mkdir compose_nginx
[root@localhost ~]# cd compose_nginx
[root@localhost compose_nginx]# mkdir nginx
[root@localhost compose_nginx]# cd nginx

[root@localhost nginx]# vim Dockerfile
FROM centos:7
RUN yum -y update
RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx
ADD nginx-1.12.0.tar.gz /usr/local/src
WORKDIR /usr/local/src
WORKDIR nginx-1.12.0
RUN ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make && make install
ENV PATH /usr/local/nginx/sbin:$PATH
EXPOSE 80
EXPOSE 443
RUN echo "daemon off;">>/usr/local/nginx/conf/nginx.conf
ADD run.sh /run.sh
RUN chmod 755 /run.sh
CMD ["/run.sh"]

[root@localhost nginx]# vim run.sh
#!/bin/bash
/usr/local/nginx/sbin/nginx

(4)創(chuàng)建編輯 yml 文件:

vim /root/compose_nginx/docker-compose.yml

version: '3'
services: 
  nginx:
    hostname: nginx
    build:
      context: ./nginx
      dockerfile: Dockerfile
    ports:
      - 1216:80      
      - 1217:443
    networks:
      - abc
    volumes:
      - ./wwwroot:/usr/local/nginx/html
networks:
  abc:

(5)此時,可以用 tree 命令,查看一下根目錄下的文件結(jié)構(gòu):

[root@localhost compose_nginx]# tree ./    ##查看樹形圖
./
├── docker-compose.yml        ##創(chuàng)建模板腳本
├── nginx
│   ├── Dockerfile            ##創(chuàng)建容器腳本
│   ├── nginx-1.12.0.tar.gz   ##源碼包
│   └── run.sh                ##服務(wù)腳本
└── wwwroot                   ##站點

(6)執(zhí)行開啟:

docker-compose -f docker-compose.yml up -d

查看鏡像和容器是否都正常且創(chuàng)建成功:
Docker Compose 容器編排 + Consul 集
(7)我們可以在站點目錄下,創(chuàng)建一個網(wǎng)頁,用瀏覽器訪問是否可以正常顯示:

[root@localhost compose_nginx]# cd wwwroot/
[root@localhost wwwroot]# vim index.html
<h2>this is nginx new web</h2>

瀏覽器訪問(IP地址為本機地址):http://192.168.220.131:1216/
Docker Compose 容器編排 + Consul 集

三、Docker concul 容器服務(wù)更新與發(fā)現(xiàn):

Docker Compose 容器編排 + Consul 集
(1)Consul:
1、Consul 是 HashCorp 公司推出的開源工具,用于實現(xiàn)分布式系統(tǒng)的服務(wù)發(fā)現(xiàn)與配置;
2、Consul 特點:

consul 支持健康檢查,允許存儲鍵值對;
一致性協(xié)議采用 Raft 算法,用來保證服務(wù)的高可用;
成員管理和消息廣播采用 GOSSIP 協(xié)議,支持 ACL 訪問控制;

3、方便部署,與 Docker 等輕量級容器可無縫配合。
(2)建立 Consul 服務(wù):
1、每個提高服務(wù)的節(jié)點上都需要部署和運行 consul 的 agent
2、Consul agent 兩種運行模式:

server;
client;

3、server 與 client 只是 consul 群集層面的區(qū)分,與搭建在 cluster 之上的應(yīng)用服務(wù)無關(guān)。

四、搭建 consul 集群:

Docker Compose 容器編排 + Consul 集
環(huán)境準備:第一臺服務(wù)器先下載一個 nginx 鏡像,供實驗使用:

[root@localhost vhost]# docker pull nginx                                //下載一個nginx鏡像

[root@localhost vhost]# docker create -it nginx:latest /bin/bash         //創(chuàng)建一個容器
be7904151f5d6cb110aba1aaa637dffeb8100c4d8761a1492e4b008dcd57d313

[root@localhost vhost]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
be7904151f5d        nginx:latest        "/bin/bash"         3 seconds ago       Created                                 xenodochial_black

架構(gòu)思維圖:
Docker Compose 容器編排 + Consul 集
部署過程:

(1)配置 consul 服務(wù)器:

[root@localhost ~]# mkdir consul
[root@localhost abc1]# cp consul_0.9.2_linux_amd64.zip /root/consul
[root@localhost abc1]# cd /root/consul

[root@localhost consul]# unzip consul_0.9.2_linux_amd64.zip     ##解壓
[root@localhost consul]# mv consul /usr/bin/                    ##便于系統(tǒng)識別

建立 Consul 服務(wù):
consul agent \
-server \
-bootstrap \
-ui \
-data-dir=/var/lib/consul-data \
-bind=192.168.220.131 \
-client=0.0.0.0 \
-node=consul-server01 &> /var/log/consul.log &

Docker Compose 容器編排 + Consul 集
(2)查看集群信息:

[root@localhost consul]# consul members
[root@localhost consul]# consul info | grep leader

Docker Compose 容器編排 + Consul 集
(3)通過 httpd api 可以獲取集群信息:

[root@localhost consul]# curl 127.0.0.1:8500/v1/status/peers                 ##查看群集server成員
[root@localhost consul]# curl 127.0.0.1:8500/v1/status/leaders               ##群集中 Raf leader
[root@localhost consul]# curl 127.0.0.1:8500/v1/catalog/services             ##注冊的所有服務(wù)
[root@localhost consul]# curl 127.0.0.1:8500/v1/catalog/nodes                ##群集節(jié)點詳細信息
[root@localhost consul]# curl 127.0.0.1:8500/v1/catalog/nginx                ##查看 nginx 服務(wù)信息

(4)讓容器服務(wù)自動加入 nginx 群集:

配置 192.168.220.140 節(jié)點:

docker run -d \
--name=registrator \
--net=host \
-v /var/run/docker.sock:/tmp/docker.sock \
--restart=always \
gliderlabs/registrator:latest \
-ip=192.168.220.140 \
consul://192.168.220.131:8500

Docker Compose 容器編排 + Consul 集
(5)測試服務(wù)、功能是否都正常:

創(chuàng)建兩個容器,分別為test-01和test02,指定端口號為83和84:

[root@localhost ~]# docker run -itd -p:83:80 --name test-01 -h test01 nginx
[root@localhost ~]# docker run -itd -p:84:80 --name test-02 -h test02 nginx

Docker Compose 容器編排 + Consul 集
(6)驗證:http 和 nginx 服務(wù)是否都注冊到了 consul :
?瀏覽器訪問:192.168.220.131:8500
?點擊 “NODES” ----> “consurl-server01” ,會出現(xiàn)剛剛創(chuàng)建的2個服務(wù)
Docker Compose 容器編排 + Consul 集
(7)實現(xiàn)容器服務(wù)自動加入 Nginx 集群:
1、consul-template:

是基于 Consul 的自動替換配置文件的應(yīng)用;
可以查詢 Consul 中的服務(wù)目錄:Key、Key-values等;
特別適合動態(tài)的創(chuàng)建配置文件;
是一個守護進程,用于實時查詢 consul 集群信息;

2、準備 template nginx 模板文件:

//在 consul 服務(wù)器上操作
創(chuàng)建一個模板文件:
vim /root/consul/nginx.ctmpl

upstream http_backend {
    {{range service "nginx"}}
     server {{.Address}}:{{.Port}};
     {{end}}
}

server {
       listen 1216;
       server_name localhost 192.168.220.131;
       access_log /var/log/nginx/kgc.cn-access.log;
       index index.html index.php;
       location / {
          proxy_set_header HOST $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header Client-IP $remote_addr; 
          proxy_set_header X-Fprwarded-For $proxy_add_x_forwarded_for;
          proxy_pass http://http_backend;
                 }
       }

Docker Compose 容器編排 + Consul 集
3、編譯安裝一個 nginx 服務(wù):

yum install gcc gcc-c++ pcre pcre-devel zlib-devel -y

tar zxvf nginx-1.12.0.tar.gz -C /opt/

./configure --prefix=/usr/local/nginx

make && make install

ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

4、配置 nginx :

[root@localhost nginx-1.12.0]# vim /usr/local/nginx/conf/nginx.conf

在 http 模板添加虛擬主機目錄:
http {
     include   mime.types;
     include vhost/*.conf;   ##添加虛擬主機目錄 
     default_type application/octet-stream;
}

Docker Compose 容器編排 + Consul 集

//創(chuàng)建虛擬主機目錄:
[root@localhost nginx-1.12.0]# mkdir /usr/local/nginx/conf/vhost

//創(chuàng)建日志文件目錄:
[root@localhost nginx-1.12.0]# mkdir /var/log/nginx

//啟動 nginx
[root@localhost nginx-1.12.0]# /usr/local/nginx/sbin/nginx
[root@localhost nginx-1.12.0]# netstat -natp | grep nginx
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      65476/nginx: master 

(8)配置并啟動 template:

1、解壓、并復(fù)制到 /bin目錄下,方便直接使用:
[root@localhost abc]# unzip consul-template_0.19.3_linux_amd64.zip 

[root@localhost abc]# mv consul-template /usr/bin/

Docker Compose 容器編排 + Consul 集
2、啟動:

consul-template -consul-addr 192.168.220.131:8500 -template "/root/consul/nginx.ctmpl:/usr/local/nginx/conf/vhost/kgc.conf:/usr/local/nginx/sbin/nginx -s reload" --log-level=info

Docker Compose 容器編排 + Consul 集
此時,我們可以再打開一個終端,查看一下根據(jù)模板生成的配置文件:
cat /usr/local/nginx/conf/vhost/kgc.conf
Docker Compose 容器編排 + Consul 集
(9)為了測試自動更新效果,我們可以在 registrator 服務(wù)端在創(chuàng)建一個 nginx 容器節(jié)點,檢測服務(wù)發(fā)現(xiàn)及配置更新功能:

[root@localhost ~]# docker run -itd -p:85:80 --name test-05 -h test05 nginx
bdc51a5c59e68c032e7466494fcb0212bae48fe939325845e00abb4840d0b48e

此時在 consul 服務(wù)器監(jiān)控中會提示自動更新,查看配置文件:
Docker Compose 容器編排 + Consul 集
(10)為了展示輪詢處理請求,可以用 logs 命令,來查看三臺 nginx 容器日志,都會顯示來自同一 IP地址的訪問:
多刷新訪問幾次 nginx 首頁:192.168.220.131:1216
Docker Compose 容器編排 + Consul 集

[root@localhost ~]# docker logs -f test-01
192.168.220.131 - - [03/Jan/2020:15:01:57 +0000] "GET / HTTP/1.0" 200 612 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"
192.168.220.131 - - [03/Jan/2020:15:02:17 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"
192.168.220.131 - - [03/Jan/2020:15:02:20 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"

[root@localhost ~]# docker logs -f test-02
192.168.220.131 - - [03/Jan/2020:15:02:18 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"
192.168.220.131 - - [03/Jan/2020:15:02:21 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"
192.168.220.131 - - [03/Jan/2020:15:02:24 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"
192.168.220.131 - - [03/Jan/2020:15:02:28 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"

[root@localhost ~]# docker logs -f test-05
192.168.220.131 - - [03/Jan/2020:15:01:57 +0000] "GET /favicon.ico HTTP/1.0" 404 153 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"
192.168.220.131 - - [03/Jan/2020:15:02:19 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"
192.168.220.131 - - [03/Jan/2020:15:02:22 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"
192.168.220.131 - - [03/Jan/2020:15:02:26 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0" "-"

可以,看出都是來自192.168.220.131的訪問,都會被以輪詢的方式發(fā)送給后臺 docker 進行處理,實現(xiàn)了負載均衡。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI