1. 程式人生 > 其它 >Docker-Compose群集編排(LNMP部署)

Docker-Compose群集編排(LNMP部署)

使用一個Dockerfile模板檔案可以定義一個單獨的應用容器,如果需要定義多個容器就需要服務編排。服務編排有很多種技術方案,例如Docker 官方產品 Docker Compose 。

Dockerfile可以讓使用者管理一個單獨的應用容器而Compose則允許使用者在一個模板(YAML格式)中定義一組相關聯的應用容器(被稱為個 project,即專案),例如一個 Web 服務容器再加上後端的資料庫服務容器等。

Docker-compose介紹

Docker-Compose專案是Docker官方的開源專案,負責實現對Docker容器叢集的快速編排單機編排

Docker-Compose將所管理的容器分為三層,分別是

工程(project)服務(service)以及容器(container)

Docker-Compose執行目錄下的所有檔案 (docker-compose.yml,extends檔案或環境變數檔案等)組成一個工程,若無特殊指定工程名即為當前目錄名。一個工程當中可包含多個服務,每個服務中定義了容器執行的映象、引數、依賴。一個服務當中可包括多個容器例項,Docker-Compose並沒有解決負載均衡的問題,因此需要藉助其它工具實現服務發現及負載均衡,比如 Consul。

Docker-Compose的工程配置檔案預設為docker-compose.yml,可通過環境變數COMPOSE_FILE或

-f引數自定義配置檔案,其定義了多個有依賴關係的服務及每個服務執行的容器。

使用一個Dockerfile模板檔案,可以讓使用者很方便的定義一個單獨的應用容器。在工作中,經常會碰到需要多個容器相互配合來完成某項任務的情況。例如要實現一個Web專案,除了Web服務容器本身,往往還需要再加上後端的資料庫服務容器,甚至還包括負載均衡容器等。

Compose允許使用者通過一個單獨的docker-compose.yml模板檔案(YAML格式)來定義一組相關聯的應用容器為一個專案(project)

Docker-Compose專案由Python編寫,呼叫Docker服務提供的API介面來對容器進行管理。因此,只要所操作的平臺支援Docker API,就可以在其上利用Compose來進行編排管理。

Compose 安裝

1. Docker Compose 環境安裝

Docker Compose 是 Docker 的獨立產品,因此需要安裝 Docker 之後在單獨安裝 Docker Compose

#下載

curl-L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s-`uname -m`-o /usr/local/bin/docker-compose

#安裝

chmod +x /usr/local/bin/docker-compose

#檢視版本

docker-compose --version

2.YAML檔案格式及編寫注意事項

YAML是一種標記語言,它可以很直觀的展示資料序列化格式,可讀性高。類似於 XML資料描述語言,語法比 XML 簡單的很多。YAML資料結構通過進來表示,連續的專案列表序列通過減號來表示,鍵值對用號分,陣列用中括號[ ]括起來,hash用花括號 { } 括起來

使用YAML時需要注意下面事項

●大小寫敏感

●通過縮排表示層級關係

●不支援製表符 tab 鍵縮排,只能使用空格縮排

●縮排的空格數目不重要,只要相同層級左對齊,通常開頭縮排2個空格

●用 # 號註釋

●符號字元後縮排1個空格,如冒號 : 、逗號, 、橫槓-

●如果包含特殊字元用單引號('')引起來會作為普通字串處理,雙引號("")∶ 特殊字元作為本身想表示的意思name:"Hi,\nTom"

資料結構∶

●物件∶鍵值對的字典

animal:pets

●陣列∶一組按次序排列的列表

- Cat

- Dog

- Goldfish

●布林值

debug: "true"

debug: "false"

#true和false包含特殊字元建議使用雙引號括起來

yaml檔案格式示例

languages:

- Java

- Golang

- Python

languages:["Java", "Golang ", " Python"]

#代表一個列表序列

websites:

Baidu: www.baidu.com

Wanqyi: www.163.com

Tengxun: www.qq.com

Sohu: www.sohu.com

#代表鍵值

Json檔案格式示例

{

languages:[

'Java',

'Golang',

'Python'

],

websites:

Baidu:'www.baidu.com',

Wangyi:'www.163.com',

Tengxun:'www.qg.com',

Sohu:'www.sohu.com'

}

#使用花括號括起來然後進行編寫,代表一個屬組和鍵值

3. Docker Compose配置常用欄位

欄位

描述

build

指定 Dockerfile 檔名要指定Dockerfile檔案需要在build標籤的子級標籤中使用dockerfile標籤指定

dockerfile

構建映象上下文路徑映象名

context

可以是 dockerfile 的路徑,或者是指向 git 倉庫的 url 地址

image

指定映象

command

執行命令,覆蓋容器啟動後預設執行的命令

container_name

指定容器名稱,由於容器名稱是唯一的,如果指定自定義名稱,則無法 scale

deploy

指定部署和執行服務相關配置,只能在 Swarm 模式使用

environment

新增環境變數

networks

加入網路,引用頂級networks下條目

ports

暴露容器埠,與 -p 相同,但埠不能低於 60

volumes

掛載一個宿主機目錄或命令捲到容器,命名卷要在頂級 volumes 定義卷名稱

volumes_from

從另一個服務或容器掛載卷,可選引數:ro 和:rw

hostname

容器主機名

sysctls

在容器內設定核心引數

links

連線到另外一個容器- 服務名稱[:服務別名]

restart

重啟策略,預設 noalwaysno-failureunless-stoped

no預設策略,在容器退出時不重啟容器。

on-failure在容器非正常退出時(退出狀態非0)才會重啟容器

on-failure:3在容器非正常退出時重啟容器,最多重啟3次always在容器退出時總是重啟容器,並且無限次

unless-stopped在容器退出時總是重啟容器,但是不考慮在 Docker守護程序啟動時就已經停止了的容器

depends_on

在使用compose時,最大的好處就是少打啟動命令,但一般專案容器啟動的順序是有要求的,如果直接從上到下啟動容器,可能會因為容器依賴問題而啟動失敗。例如在沒啟動資料庫容器的時候啟動應用容器,應用容器會因為找不到資料庫而退出。depends on標籤用於解決容器的依賴、啟動先後的問題。php:

depends_on:

- apache

- mysql

4.Docker Compose 常用命令

欄位

描述

build

重新構建服務

ps

列出容器

up

建立和啟動容器

exec

在容器裡面執行命令

scale

指定一個服務容器啟動數量

top

顯示容器程序

logs

檢視容器輸出

down

刪除容器、網路、資料卷和映象

stop/start/restart

停止/啟動/重啟服務

5.Docker Compose 檔案結構

yum install-y tree

tree /opt/compose_lnmp

Docker Compose管理LNMP+wordpress容器

mkdir /opt/compose_lnmp

cd /opt/compose_lnmp/

#將之前LNMP架構各容器的Dockerfile目錄複製到/opt/compose_lnmp/該目錄下

#可以參考前一篇的LNMP+Wordpress容器的部署https://www.cnblogs.com/pengdi/p/15412935.html

cp /opt/nginx /opt/compose_lnmp/

cp /opt/mysql /opt/compose_lnmp/

cp /opt/php /opt/compose_lnmp/

編寫docker-compose.yml檔案

vim docker-compose.yml                                       #嚴格注意最頂級和每層之間的縮排格式
#這裡版本有1,2,3種,1已經廢棄,2支援單機,3支援單機和多機,但是3會顯示無法讀取volumes_from:的配置,所以還是使用2
version: "2" 
services:
  nginx:                                                     #配置nginx容器啟動
    build:                                                   #定義Dockerfile檔名和路徑
      context: ./nginx  
      dockerfile: Dockerfile                 
    container_name: nginx                                    #定義容器名
    ports:                                                   #新增對映埠,根據需求設定
      - 1555:80
      - 1666:443
    networks:                                                #自定義網路
      lnmp:
        ipv4_address: 172.20.0.10
    volumes:                                                 #定義掛載的宿主機目錄
      - ./nginx/html/:/usr/local/nginx/html
      - ./nginx/conf/:/usr/local/nginx/conf
    hostname: nginx                                          #定義容器內的主機名

  mysql:                                                     #配置mysql容器啟動
    build:
      context: ./mysql
      dockerfile: Dockerfile
    container_name: mysql
    ports:
      - 3306:3306
    networks:
      lnmp:
        ipv4_address: 172.20.0.20
    hostname: mysql

  php:
    build:
      context: ./php
      dockerfile: Dockerfile
    container_name: php
    ports:
      - 9000:9000
    networks:
      lnmp:
        ipv4_address: 172.20.0.30
    hostname: php
volumes_from:                                                #掛載別的容器
      - nginx
      - mysql
networks:                                                    #自定義網路資訊的格式
  lnmp:                                                        
    driver: bridge
    ipam:
      config:
        - subnet: 172.20.0.0/16                              #自定義網段
#注意這裡使用的是其他自定義網段172.20.0.0,nginx.conf中轉發的php容器地址,和php容器的擴充套件配置檔案www.conf的監聽地址需要更改

docker-compose -f docker-compose.yml up -d
-f∶--file FILE ∶使用特定的 compose 模板檔案,預設為 docker-compose.yml
-P∶--project-name NAME ∶指定專案名稱,預設使用目錄名稱
-d∶在後臺執行
docker ps -a
docker-compose ps                                           #檢視docker-compose管理的容器

進入資料庫建立wordpress資料庫並授予遠端訪問的許可權

進入資料庫建立wordpress資料庫並授予遠端訪問的許可權
docker exec -it mysql /bin/bash

mysql
create database wordpress;
grant all privileges on wordpress.* to 'wordpress'@'%' identified by '123456';
grant all privileges on *.* to 'root'@'%' identified by '123456';
flush privileges;
#web頁面進行訪問驗證
http://192.168.150.30:1555/wordpress/index.php                                     #加上配置的埠號進行訪問