“寒江孤影,江湖故人”。
在Docker走馬江湖的青蔥歲月里,面對云時代的巍然大勢下,Docker曾也浪跡江湖,執(zhí)三劍以掃天下,飲馬江湖,仗劍天涯。今朝聲名已著,江湖時傳,三劍客也。
Docker三劍客之Docker-Machine
DockerMachine:docker-machine就是docker公司官方提出的用于在各種平臺上快速創(chuàng)建具有docker服務(wù)的技術(shù),主要是解決docker運(yùn)行環(huán)境問題。
Docker三劍客之Docker-Compose
Docker-compose:是用來定義和運(yùn)行多容器應(yīng)用的工具,主要是解決本地docker容器編排問題。
Docker三劍客之Docker-Swarm
DockerSwarm:是Docker社區(qū)原生提供的容器集群管理工具,是解決多主機(jī)多個容器調(diào)度部署的問題。
在docker后續(xù)的發(fā)展浪潮中,docker-machine的能力范圍主要用于處理陳舊系統(tǒng)的中docker部署及遠(yuǎn)程系統(tǒng)上配置docker的需求。docker-compose作為docker的一項(xiàng)開源項(xiàng)目獨(dú)立維護(hù)。而docker-swarm被docker吸收嵌入到dockerengine中成為docker的子命令。本文僅以docker-compose為出發(fā)點(diǎn),詳細(xì)分析下其功能作用和配置特點(diǎn)。
Compose是用于定義和運(yùn)行多容器Docker應(yīng)用程序的工具。通過Compose,您可以使用YAML文件來配置應(yīng)用程序的服務(wù)。然后,使用一個命令,就可以從配置中創(chuàng)建并啟動所有服務(wù)。
Compose通過一個配置文件來管理多個Docker容器,在配置文件中,所有的容器通過services來定義,然后使用docker-compose腳本來啟動,停止和重啟應(yīng)用,和應(yīng)用中的服務(wù)以及所有依賴服務(wù)的容器,非常適合組合使用多個容器進(jìn)行開發(fā)的場景。
使用compose基本上是一個三步過程:
1.用dockerfile,或者鏡像定義應(yīng)用程序的環(huán)境,以便在任何地方復(fù)制。
2.在docker-compose.yml中定義組成應(yīng)用程序的服務(wù),以便它們可以在多帶帶的環(huán)境中一起運(yùn)行。
3.運(yùn)行dockercompose up啟動并運(yùn)行整個應(yīng)用程序。
docker-compose將所管理的容器分為3層結(jié)構(gòu):Project 、Service 、Container。docker-compose.yml組成一個project,project中包括多個service,每個service定義了容器運(yùn)行的鏡像(或構(gòu)建鏡像),網(wǎng)絡(luò)端口,文件掛載,參數(shù),依賴等,每個service又可以包括同一個鏡像的多個容器實(shí)例。
因?yàn)閐ocker-compose的運(yùn)行還是依賴docker容器的,故docker也是事先部署好的;另外還要注意的是,docker-compose的運(yùn)行版本也是需要和本地運(yùn)行的dockerengine的版本是統(tǒng)一的。
Docker安裝
$ sudo yum install -y yum-utils
$ sudo yum-config-manager
--add-repo
https://download.docker.com/linux/centos/docker-ce.repo
配置dockeryum源:
$ sudo yum install docker-ce docker-ce-cli containerd.io
安裝最新版dockerengine:
安裝指定版本的dockerengine:
注:文件演示docker安裝版本:Dockerversion 18.09.0, build 4d60db4
Docker-compose安裝:
$ yum list docker-ce --showduplicates | sort -r
docker-ce.x86_64 3:18.09.1-3.el7 docker-ce-stable
docker-ce.x86_64 3:18.09.0-3.el7 docker-ce-stable
docker-ce.x86_64 18.06.1.ce-3.el7 docker-ce-stable
docker-ce.x86_64 18.06.0.ce-3.el7 docker-ce-stable
$ sudo yum install docker-ce-
docker-ce-cli-
$ sudo curl -L "https://github.com/docker/compose/releases/download/1.26.2/
docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
$ sudo chmod +x /usr/local/bin/docker-compose
$ sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
注意:要安裝其他版本的Compose,請?zhí)鎿Q1.26.2 為要使用的Compose版本。另外github網(wǎng)絡(luò)連接不好的情況可能下載失敗,可以去github上直接下載上傳到本地服務(wù)器。文中docker-compose安裝版本:docker-composeversion 1.18.0, build 8dd22a9
本次示例采用的是wordpress+mysql部署一個博客項(xiàng)目:
Docker-compose.yml文件配置內(nèi)容如下:
version: 3.1 services: wordpress: image: wordpress restart: always ports: - 8080:80 environment: WORDPRESS_DB_HOST: db WORDPRESS_DB_USER: wp WORDPRESS_DB_PASSWORD: 123456 WORDPRESS_DB_NAME: wordpress volumes: - wordpress:/var/www/html db: image: mysql:5.7 restart: always environment: MYSQL_DATABASE: wordpress MYSQL_USER: wp MYSQL_PASSWORD: 123456 MYSQL_RANDOM_ROOT_PASSWORD: 1 volumes: - db:/var/lib/mysql volumes: wordpress: db: |
Docker-compose啟動wordpress博客項(xiàng)目,這里統(tǒng)稱上述yml文件中描述的服務(wù)都是來完成博客項(xiàng)目的,其中service有兩個:wordpress服務(wù)和MySQL服務(wù)。
至此我們使用docker-compose來啟動該項(xiàng)目:
#進(jìn)入docker-compose.yml文件所在目錄執(zhí)行命令
$ sudo docker-compose up -d
#或者啟動docker-compose.yml文件來啟動
$ sudo docker-compose -f /yml_dir/docker-compose.yml up -d
查看容器啟動情況:
]# docker-compose ps
Name Command State Ports
-------------------------------------------------------------------------------------
wordpress_db_1 docker-entrypoint.sh mysqld Up 3306/tcp, 33060/tcp
wordpress_wordpress_1 docker-entrypoint.sh apach ... Up 0.0.0.0:8080->80/tcp
Wordpress頁面配置展示效果:
從演示的結(jié)果來看,docker-compose確實(shí)完成了我們期望的工作,在一次部署中完成對項(xiàng)目中所有服務(wù)的構(gòu)建管控。從服務(wù)器環(huán)境上來說,compose使用項(xiàng)目名稱的方式將環(huán)境相互隔離;并且支持環(huán)境變量,方便用戶使用這些變量應(yīng)用在不用的環(huán)境中,用戶自定義設(shè)置變量等方面。從應(yīng)用上看過了compose的功能特點(diǎn),接下來我們看看從yml文件配置中看看docker-compose都完成了什么。
version:指定docker-compose.yml文件的寫法格式
version: 3.1
services:多個服務(wù)集合,例如文件中wordpress和db都是服務(wù):
services:
wordpress:
db:
image:指定服務(wù)所使用的鏡像:
version: 3.1
services:
wordpress:
image: wordpress
restart:always :配置重啟,docker每次啟動時會啟動該服務(wù)
restart:always
ports:定義宿主機(jī)端口和容器端口的映射,可使用宿主機(jī)IP+宿主機(jī)端口進(jìn)行訪問宿主機(jī)端口:容器端口
environment:環(huán)境變量配置,可以用數(shù)組或字典兩種方式
volumes:卷掛載路徑,定義宿主機(jī)的目錄/文件和容器的目錄/文件的映射 宿主機(jī)
ports:
- 8080:80
environment:
WORDPRESS_DB_HOST: db #此項(xiàng)配置引用 服務(wù) db的名稱,
WORDPRESS_DB_USER: wp
WORDPRESS_DB_PASSWORD: 123456
WORDPRESS_DB_NAME: wordpress
volumes:#此處wordpress為數(shù)據(jù)卷
- wordpress:/var/www/html
路徑:容器路徑
docker-composepull:拉取服務(wù)里定義的鏡像
docker-composeps :列出project所有運(yùn)行容器(容器名= 目錄名_service_index index表示容器序數(shù),從1開始)
docker-composebuild:構(gòu)建/重新構(gòu)建所有鏡像
docker-composestart [serviceName]:啟動已存在但停止的所有service;
(可選)[serviceName]:表示啟動某一個service
docker-composeup -d(相當(dāng)于build + start ):構(gòu)建(容器)并啟動(容器)整個project的所有service
-d:后臺進(jìn)程
--scale:指定服務(wù)運(yùn)行的容器個數(shù)
docker-composestop [serviceName]:停止運(yùn)行的service
(可選)[serviceName]:表示停止某一個service
docker-composerm -f [serviceName]:刪除已停止的所有service
(可選)[serviceName]:表示刪除已停止某一個service
-f :刪除不在詢問
docker-composedown -v(相當(dāng)于stop + rm):停止并移除整個project的所有services
-v:刪除掛載卷和volunme的鏈接
docker-composelogs [serviceName]:查看服務(wù)內(nèi)所有容器日志輸出
(可選)[serviceName]:表示輸出某一個service的日志
-f:實(shí)時輸出日志
docker-composerun [serviceName] command:在某個服務(wù)上運(yùn)行命令
eg:docker-compose run web ping www.baidu.com
docker-composeexec [serviceName] sh:進(jìn)入到某個容器
--index:2 :當(dāng)服務(wù)內(nèi)有多個容器時,需要指定第幾個,默認(rèn)是第一個
eg:docker-composeexec --index=2 web sh
docker-composerestart [serviceName] : 重啟服務(wù)
docker-composeconfig:驗(yàn)證和查看compose文件
docker-compose images:列出所用的鏡像
docker-cpmposescale:設(shè)置服務(wù)個數(shù)Eg:docker-compose scale web=2 worker=3
docker-composepause [serviceName]:暫停服務(wù)
docker-composeunpause [serviceName]:恢復(fù)服務(wù)
通過本次演練完整了體現(xiàn)了docker-compose在單臺主機(jī)上運(yùn)行多個獨(dú)立環(huán)境的能力及環(huán)境變量設(shè)置等有力手段,其實(shí)compose在對數(shù)據(jù)卷的使用及只重新創(chuàng)建改變的容器方式也極大的提高了compose的使用便利性。但局限性也很明顯就是單臺服務(wù)器上部署,無法保證高可用性,故而在越來越多的集群方式的環(huán)境下,使用場景也變的單一。所以在后續(xù)的使用中,要切合場景要求,一切以現(xiàn)場實(shí)際為出發(fā)點(diǎn),提出有效正確的方案。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/130141.html
摘要:常用服務(wù)配置一些基礎(chǔ)服務(wù)的配置文件,方便在一臺新電腦上快速開始工作不必輸入一長串命令來啟動對應(yīng)服務(wù),并且可以做到持久化。 docker-compose 常用服務(wù)配置 一些基礎(chǔ)服務(wù)的docker-compose配置文件,方便在一臺新電腦上快速開始工作 不必輸入一長串docker命令來啟動對應(yīng)服務(wù),并且可以做到持久化。 代碼托管在 https://github.com/shiguanghu...
摘要:我創(chuàng)建了一個名為的項(xiàng)目。錯誤信息查看在后臺找到我們的項(xiàng)目,點(diǎn)擊進(jìn)去就能看到多了一條錯誤信息。它由以下幾部分組成,分別是協(xié)議公鑰私鑰主機(jī)路徑一般為空項(xiàng)目。 sentry簡介 Sentry 是一個開源的錯誤追蹤工具,可以幫助開發(fā)人員實(shí)時監(jiān)控和修復(fù)系統(tǒng)中的錯誤。其專注于錯誤監(jiān)控以及提取一切事后處理所需的信息;支持幾乎所有主流開發(fā)語言(JS/Java/Python/php)和平臺, 并提供了w...
閱讀 1356·2023-01-11 13:20
閱讀 1707·2023-01-11 13:20
閱讀 1215·2023-01-11 13:20
閱讀 1906·2023-01-11 13:20
閱讀 4165·2023-01-11 13:20
閱讀 2757·2023-01-11 13:20
閱讀 1402·2023-01-11 13:20
閱讀 3671·2023-01-11 13:20