Docker-Compose群集編排(LNMP部署)
使用一個Dockerfile模板檔案可以定義一個單獨的應用容器,如果需要定義多個容器就需要服務編排。服務編排有很多種技術方案,例如Docker 官方產品 Docker Compose 。
Dockerfile可以讓使用者管理一個單獨的應用容器,而Compose則允許使用者在一個模板(YAML格式)中定義一組相關聯的應用容器(被稱為一個 project,即專案),例如一個 Web 服務容器再加上後端的資料庫服務容器等。
Docker-compose介紹
Docker-Compose專案是Docker官方的開源專案,負責實現對Docker容器叢集的快速編排(單機編排)
Docker-Compose將所管理的容器分為三層,分別是
Docker-Compose執行目錄下的所有檔案 (docker-compose.yml,extends檔案或環境變數檔案等)組成一個工程,若無特殊指定工程名即為當前目錄名。一個工程當中可包含多個服務,每個服務中定義了容器執行的映象、引數、依賴。一個服務當中可包括多個容器例項,Docker-Compose並沒有解決負載均衡的問題,因此需要藉助其它工具實現服務發現及負載均衡,比如 Consul。
Docker-Compose的工程配置檔案預設為docker-compose.yml,可通過環境變數COMPOSE_FILE或
使用一個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 |
重啟策略,預設 no、always、no-failure、unless-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 #加上配置的埠號進行訪問