亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

詳解docker compose 用法

瀏覽:38日期:2024-11-17 14:09:49
docker compose的使用場(chǎng)景

我們開(kāi)發(fā)的時(shí)候,一個(gè)應(yīng)用往往依賴多個(gè)服務(wù)。采用傳統(tǒng)的docker run方式,要挨個(gè)啟動(dòng)多個(gè)服務(wù),甚至需要配置對(duì)應(yīng)的網(wǎng)絡(luò),過(guò)程比較繁瑣,很不方便。 docker compose旨在通過(guò)將多服務(wù)的構(gòu)建和依賴關(guān)系都編寫在docker-compose.yml中,通過(guò)docker-compose命令,即可完成對(duì)整個(gè)服務(wù)集群的啟動(dòng),關(guān)閉等操作。

一個(gè)基本的demo演示

demo的功能是一個(gè)簡(jiǎn)單的python程序,暴露一個(gè)web服務(wù)。該服務(wù)用于統(tǒng)計(jì)當(dāng)前服務(wù)被訪問(wèn)的次數(shù)。次數(shù)的累加和存儲(chǔ),都是基于redis進(jìn)行的。也即該程序本身除了自己的服務(wù),還要依賴一個(gè)redis服務(wù)。以下是詳細(xì)步驟

找一個(gè)目錄,在其中創(chuàng)建一個(gè)python文件app.py

import timeimport redisfrom flask import Flaskapp = Flask(__name__)cache = redis.Redis(host=’redis’, port=6379)def get_hit_count(): retries = 5 while True: try: return cache.incr(’hits’) except redis.exceptions.ConnectionError as exc: if retries == 0: raise exc retries -= 1 time.sleep(0.5)@app.route(’/’)def hello(): count = get_hit_count() return ’Hello World! I have been seen {} times.n’.format(count)

在相同的文件夾下,創(chuàng)建requirements.txt文件

requirements.txt文件用來(lái)聲明python程序需要使用到的依賴lib,有點(diǎn)像java中的maven pom文件。上述代碼使用的組件有flask和redis。所以requirements.txt文件內(nèi)容為

flaskredis

在相同的文件夾下,創(chuàng)建Dockerfile

Dockerfile用來(lái)將我們的程序構(gòu)建成一個(gè)docker 鏡像,即docker image。一般Dockerfile中會(huì)定義我們的代碼運(yùn)行的基本環(huán)境,程序啟動(dòng)命令,執(zhí)行端口等。本例的Dockerfile如下

FROM python:3.7-alpineWORKDIR /codeENV FLASK_APP=app.pyENV FLASK_RUN_HOST=0.0.0.0COPY requirements.txt requirements.txtRUN pip install -r requirements.txtEXPOSE 5000COPY . .CMD ['flask', 'run']

在相同的文件下,創(chuàng)建docker-compose.yml文件

上述幾步完成后,我們得到了我們服務(wù)本身的docker化執(zhí)行的能力。但該服務(wù)依賴redis service。所以我們通過(guò)docker-compose.yml來(lái)組織服務(wù)的依賴關(guān)系,內(nèi)容如下:

version: '3.8'services: web: build: . ports: - '5000:5000' redis: image: 'redis:alpine'

文件中定義了兩個(gè)服務(wù)web和redis , web中的build:. 會(huì)在當(dāng)前目錄下基于前面定義的Dockerfile將我們的代碼構(gòu)建成一個(gè)image,然后啟動(dòng)成一個(gè)container時(shí),會(huì)對(duì)外暴露5000端口,映射到當(dāng)前宿主機(jī)的端口也是5000

redis服務(wù)直接使用現(xiàn)成的image redis:alpine,沒(méi)有指定端口,將暴露redis的默認(rèn)端口

基礎(chǔ)運(yùn)維

所有docker-compose相關(guān)的命令,都要在docker-compose.yml所在的路徑下執(zhí)行才行

啟動(dòng)基于docker-compose.yml編織好的服務(wù)

在docker-compose.yml所在的目錄,使用命令docker-compose up即可。但該命令在console關(guān)閉時(shí),對(duì)應(yīng)的docker service也會(huì)被關(guān)閉。可以是使用docker-compose up -d 以后臺(tái)detach模式去執(zhí)行。

docker-compose up 也可以單獨(dú)啟動(dòng)compolse file中的某個(gè)服務(wù)及其依賴

查看compose服務(wù)對(duì)應(yīng)的容器服務(wù)列表

docker-compose ps

輸出結(jié)果樣例

# docker-compose ps Name Command State Ports----------------------------------------------------------------------------------------------docker_compose_learn_redis_1 docker-entrypoint.sh redis ... Up 6379/tcpdocker_compose_learn_web_1 flask runUp 0.0.0.0:5000->5000/tcp

服務(wù)前綴docker_compose_learn是當(dāng)前項(xiàng)目的名稱。項(xiàng)目名稱可以通過(guò)環(huán)境變量COMPOSE_PROJECT_NAME來(lái)指定,如果未指定,默認(rèn)的項(xiàng)目名稱為compose 文件所在文件夾的名字。本例中的文件夾名為docker_compose_learn

當(dāng)然compose的一系列服務(wù),最終也是啟動(dòng)了一系列的container. 所以也可使用docker container命令族進(jìn)行管理,但是太麻煩

停止service的container

需要在docker-compose.yml所在的路徑,使用命令docker-compose stop

停止service的container,并且刪除對(duì)應(yīng)的container

需要在docker-compose.yml所在的路徑,使用命令

docker-compose down

停止service的container,并且刪除對(duì)應(yīng)的container和對(duì)應(yīng)的volumes數(shù)據(jù)

需要在docker-compose.yml所在的路徑,使用命令

docker-compose down --volumes

該命令并不會(huì)刪除掛載的宿主操作系統(tǒng)的文件。

如何登進(jìn)對(duì)應(yīng)的service

想要登錄到compose中,具體某個(gè)service的命令行,使用如下命令

docker-compose exec ***servicename*** bash

詳解docker compose 用法

如何顯示指定compose file

docker-compose -f docker-compose.yml -f docker-compose.admin.yml run backup_dbdocker-compose up和docker-compose run的區(qū)別

docker-compose up會(huì)基于compose file 啟動(dòng)所有的的服務(wù),并對(duì)外暴露端口docker-compose run需要指定特定的服務(wù)進(jìn)行啟動(dòng),比如docker-compose run web bash只會(huì)啟動(dòng)compolse文件中的web服務(wù)和其依賴的service,并且不會(huì)對(duì)外暴露端口,以免跟docker-compose up啟動(dòng)的服務(wù)端口沖突。docker-compose run僅用在臨時(shí)啟動(dòng)某個(gè)服務(wù)定位問(wèn)題的場(chǎng)景

一些擴(kuò)展知識(shí)點(diǎn)

環(huán)境變量

docker-compose.yml的內(nèi)容本身可以使用變量占位符,其具體的變量值定義在具體的環(huán)境變量中,這樣方便同一份docker-compose.yml文件在不同的環(huán)境有不同的執(zhí)行行為。典型的,我們希望依賴服務(wù)的image的tag版本,隨環(huán)境不同而不同。

那么我們?cè)赿ocker-compose.yml對(duì)應(yīng)的服務(wù)配置中以占位符配置其tag,以下用${TAG}配置web服務(wù)的image tag

web: image: 'webapp:${TAG}'

除了指定以的變量意外,還有多個(gè)docker內(nèi)置的變量可以設(shè)置,他們用來(lái)配置docker的或者docker compose的執(zhí)行行為。這些內(nèi)置變量是

COMPOSE_API_VERSION COMPOSE_CONVERT_WINDOWS_PATHS COMPOSE_FILE COMPOSE_HTTP_TIMEOUT COMPOSE_TLS_VERSION COMPOSE_PROJECT_NAME DOCKER_CERT_PATH DOCKER_HOST DOCKER_TLS_VERIFY

具體含義參見(jiàn);https://docs.docker.com/compose/reference/envvars/

以占位符TAG為例,講解變量的設(shè)置可以有以下幾種方式

在docker-compose.yml中執(zhí)行

在compolse文件中,通過(guò)environment配置項(xiàng)指定

web: image: 'webapp:${TAG}' environment: - TAG=dev

在執(zhí)行docker-compose 命令之前設(shè)置shell環(huán)境變量

$ export TAG=v2.0$ docker-compose up

通過(guò)env_file文件設(shè)置

docker-compose up默認(rèn)會(huì)找命令執(zhí)行路徑下的.env文件,去其中找變量替換的值,.env文件以key=value的形式配置。例如

TAG=dev

如果環(huán)境變量的名字不為.env或不在當(dāng)前命令執(zhí)行的路徑下,可以在使用--env-file參數(shù)顯示加載

docker-compose --env-file ./config/.env.dev up

直接在compose 文件中,指定其加載的env_file

version: ’3’services: api: image: ’node:6-alpine’ env_file: - ./Docker/api/api.env environment: - NODE_ENV=production

以上變量值設(shè)置優(yōu)先級(jí)從高到底

查看最終生效的環(huán)境變量

如果不確定最終生效環(huán)境變量是什么樣,可以使用以下命令來(lái)查看

docker-compose run web env

項(xiàng)目名設(shè)定

一個(gè)compose對(duì)應(yīng)的一組服務(wù)有一個(gè)公用的項(xiàng)目名(project name), 它會(huì)體現(xiàn)在compose服務(wù)的容器名前綴中,網(wǎng)絡(luò)前綴中。項(xiàng)目名稱可以通過(guò)環(huán)境變量COMPOSE_PROJECT_NAME來(lái)指定,如果未指定,默認(rèn)的項(xiàng)目名稱為compose 文件所在文件夾的名字。

網(wǎng)絡(luò)

默認(rèn)網(wǎng)絡(luò)

默認(rèn)情況下,compose中的多個(gè)服務(wù)會(huì)加入一個(gè)名為default的網(wǎng)絡(luò)。這些服務(wù)在default網(wǎng)絡(luò)中是互通的。該default網(wǎng)絡(luò)的全稱是以compose文件所在文件夾名字做為前綴。比如文件夾為hello_world的compose。其一組服務(wù)對(duì)應(yīng)的網(wǎng)絡(luò)名為:hello_world_default。 這組service在該網(wǎng)絡(luò)中,以compose文件中的第二組端口通信。

version: '3'services: web: build: . ports: - '8000:8000' db: image: postgres ports: - '8001:5432'

比如上述配置中,在hello_world_default網(wǎng)絡(luò)中,web服務(wù)使用8000端口和db服務(wù)的5432端口通信。第一組端口8000和8001是宿主機(jī)訪問(wèn)web和db服務(wù)的端口。

對(duì)默認(rèn)網(wǎng)絡(luò)進(jìn)行獨(dú)立配置

如果想改變默認(rèn)網(wǎng)絡(luò)的配置,可以在compose文件中,單獨(dú)通過(guò)networks項(xiàng)來(lái)改變,比如以下改變默認(rèn)網(wǎng)絡(luò)驅(qū)動(dòng)

networks: default: # Use a custom driver driver: custom-driver-1

配置和使用非默認(rèn)網(wǎng)絡(luò)

定義多個(gè)網(wǎng)絡(luò),并使用

version: '3'services: proxy: build: ./proxy networks: - frontend app: build: ./app networks: - frontend - backend db: image: postgres networks: - backendnetworks: frontend: # Use a custom driver driver: custom-driver-1 backend: # Use a custom driver which takes special options driver: custom-driver-2 driver_opts: foo: '1' bar: '2'

上述配置定義了兩個(gè)網(wǎng)絡(luò),frontend 和 backend。其中app 能訪問(wèn)這兩個(gè)網(wǎng)絡(luò),proxy服務(wù)只能訪問(wèn)frontend網(wǎng)絡(luò),db只能訪問(wèn)backend網(wǎng)絡(luò)

多service的執(zhí)行順序

一個(gè)compose的多個(gè)service可能會(huì)有依賴關(guān)系,比如web服務(wù)依賴db服務(wù),我們希望先啟動(dòng)db服務(wù),再啟動(dòng)web服務(wù)。這種啟動(dòng)的先后順序,也可以在compose文件中使用depends_on指定

version: '2'services: web: build: . ports: - '80:8000' depends_on: - 'db' command: ['./wait-for-it.sh', 'db:5432', '--', 'python', 'app.py'] db: image: postgresdocker compose的安裝

docker mac版和windows版,默認(rèn)都帶有docker compose 。 只有l(wèi)inux版需要單獨(dú)安裝

docker compose和docker stack的異同 docker compose主要目標(biāo)是在同一臺(tái)機(jī)器上啟動(dòng)并管理多個(gè)服務(wù) docker stack主要用于在多個(gè)機(jī)器上,啟動(dòng)并管理多個(gè)服務(wù) docker compose 和docker stack都可以使用docker-compose.yml文件。雙方會(huì)自動(dòng)忽略對(duì)自己不生效的配置 docker compose的服務(wù)可以使用build動(dòng)態(tài)構(gòu)建,而docker stack的服務(wù)只能基于image參考資料

https://docs.docker.com/compose/gettingstarted/https://docs.docker.com/compose/https://stackoverflow.com/questions/43099408/whats-the-difference-between-a-stack-file-and-a-compose-filehttps://nickjanetakis.com/blog/docker-tip-23-docker-compose-vs-docker-stackhttps://vsupalov.com/difference-docker-compose-and-docker-stack/https://stackoverflow.com/questions/33066528/should-i-use-docker-compose-up-or-run

到此這篇關(guān)于docker compose 用法的文章就介紹到這了,更多相關(guān)docker compose 用法內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Docker
相關(guān)文章:
主站蜘蛛池模板: 色婷婷综合久久久中文字幕 | 999精品久久久中文字幕蜜桃 | 国产成人综合亚洲欧美在线n | 国产精品视频第一区二区 | 国产酒店视频 | 国产黑丝在线播放 | 久热香蕉精品视频在线播放 | 黑人好太好长爱不了 | 日韩精品一区二区三区中文 | 美女久久久久久久久久久 | 99久久精品费精品国产一区二区 | 全免费a级毛片免费毛视频 全免费a级毛片免费看 | 亚洲一区二区免费视频 | 一级片手机在线 | 国产午夜免费视频片夜色 | 69欧美xxxxx色护士视频 | 激情图片在线视频 | 国产成人 免费观看 | 天天影视综合网色综合国产 | 大尺度一级毛片波多野结衣 | 鲁大师在线观看免费播放 | 国产一区二区三区在线免费观看 | 久久精品国产只有精品2020 | 高清色黄毛片一级毛片 | 在线不卡一区 | 美女视频黄a视频全免费网站一区 | 亚洲国产精品久久久久网站 | 国产精品自线在线播放 | 九九香蕉视频 | 黄色免费看片网站 | 欧洲色图亚洲色图 | 国产精品亚洲欧美日韩一区在线 | 91看片淫黄大片一级在线观看 | 国产丝袜视频在线 | 妖精视频免费入口 | 青春草在线视频精品 | 中日韩免费视频 | 亚洲精品成人456在线播放 | 亚洲欧美日韩综合久久久久 | 久久久久久88色愉愉 | 日鲁夜鲁天天鲁视频 |