婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解docker compose 用法

詳解docker compose 用法

熱門標(biāo)簽:企業(yè)辦理400電話收費(fèi)標(biāo)準(zhǔn) 智能電銷機(jī)器人真的有用么 高德地圖標(biāo)注足跡怎么打標(biāo) 百度地圖底圖標(biāo)注 電銷智能機(jī)器人試用 新鄉(xiāng)牧野400電話申請 撫州市城區(qū)地圖標(biāo)注 激光標(biāo)記地圖標(biāo)注 中國地圖標(biāo)注上各個省

docker compose的使用場景

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

一個基本的demo演示

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

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

import time

import redis
from flask import Flask

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

flask
redis

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

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

FROM python:3.7-alpine
WORKDIR /code
ENV FLASK_APP=app.py
ENV FLASK_RUN_HOST=0.0.0.0
COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt
EXPOSE 5000
COPY . .
CMD ["flask", "run"]

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

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

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

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

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

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

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

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

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

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

查看compose服務(wù)對應(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/tcp
docker_compose_learn_web_1     flask run                        Up      0.0.0.0:5000->5000/tcp

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

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

停止service的container

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

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

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

docker-compose down

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

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

docker-compose down --volumes

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

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

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

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

如何顯示指定compose file

docker-compose -f docker-compose.yml -f docker-compose.admin.yml run backup_db

docker-compose up和docker-compose run的區(qū)別

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

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

環(huán)境變量

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

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

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

除了指定以的變量意外,還有多個docker內(nèi)置的變量可以設(shè)置,他們用來配置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

具體含義參見;https://docs.docker.com/compose/reference/envvars/

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

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

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

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

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

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

通過env_file文件設(shè)置

docker-compose up默認(rèn)會找命令執(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)先級從高到底

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

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

docker-compose run web env

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

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

網(wǎng)絡(luò)

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

默認(rèn)情況下,compose中的多個服務(wù)會加入一個名為default的網(wǎng)絡(luò)。這些服務(wù)在default網(wǎng)絡(luò)中是互通的。該default網(wǎng)絡(luò)的全稱是以compose文件所在文件夾名字做為前綴。比如文件夾為hello_world的compose。其一組服務(wù)對應(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ī)訪問web和db服務(wù)的端口。

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

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

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

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

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

version: "3"
services:

 proxy:
 build: ./proxy
 networks:
  - frontend
 app:
 build: ./app
 networks:
  - frontend
  - backend
 db:
 image: postgres
 networks:
  - backend

networks:
 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"

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

多service的執(zhí)行順序

一個compose的多個service可能會有依賴關(guān)系,比如web服務(wù)依賴db服務(wù),我們希望先啟動db服務(wù),再啟動web服務(wù)。這種啟動的先后順序,也可以在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: postgres

docker compose的安裝

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

docker compose和docker stack的異同

  • docker compose主要目標(biāo)是在同一臺機(jī)器上啟動并管理多個服務(wù)
  • docker stack主要用于在多個機(jī)器上,啟動并管理多個服務(wù)
  • docker compose 和docker stack都可以使用docker-compose.yml文件。雙方會自動忽略對自己不生效的配置
  • docker compose的服務(wù)可以使用build動態(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-file
https://nickjanetakis.com/blog/docker-tip-23-docker-compose-vs-docker-stack
https://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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

標(biāo)簽:辛集 延安 臨汾 忻州 邯鄲 南通 西安 海西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解docker compose 用法》,本文關(guān)鍵詞  詳解,docker,compose,用法,詳解,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解docker compose 用法》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解docker compose 用法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91精品国产一区二区三区| 国产成人av影院| 国产精品第13页| xvideos.蜜桃一区二区| 欧美一二三四区在线| 91精品国产综合久久蜜臀| 欧美一级xxx| 国产亚洲欧美色| 久久精品亚洲精品国产欧美kt∨| 国产情人综合久久777777| 亚洲国产成人自拍| 亚洲日本韩国一区| 亚洲成人黄色小说| 黑人精品欧美一区二区蜜桃| 国产美女av一区二区三区| 国产电影一区在线| 97精品国产露脸对白| 欧美中文字幕一区| 日韩欧美视频在线| 亚洲欧洲另类国产综合| 亚洲午夜私人影院| 国产精品一区免费视频| aaa欧美色吧激情视频| 91高清视频免费看| 日韩一区二区三区高清免费看看| 久久综合av免费| 亚洲视频一区二区在线观看| 日韩av中文在线观看| 国产成人丝袜美腿| 欧美老肥妇做.爰bbww| 国产欧美综合色| 无码av中文一区二区三区桃花岛| 国内精品国产成人国产三级粉色| av亚洲精华国产精华| 日韩欧美在线1卡| 中文字幕一区三区| 精品一区二区在线免费观看| 色综合久久综合网欧美综合网| 6080午夜不卡| 亚洲精选免费视频| 国产成人精品三级| 欧美男女性生活在线直播观看| 欧美国产欧美综合| 日本中文一区二区三区| 色呦呦网站一区| 国产欧美一区二区在线| 蜜臀av性久久久久蜜臀aⅴ| 99视频有精品| 国产亚洲午夜高清国产拍精品| 亚洲午夜一二三区视频| 91丨九色porny丨蝌蚪| 欧美精品一区二区蜜臀亚洲| 亚洲国产视频直播| 色婷婷av久久久久久久| 国产精品伦理一区二区| 激情综合色播激情啊| 欧美一级二级在线观看| 婷婷综合另类小说色区| 欧美日韩一区二区三区在线看| 国产精品久久777777| 成人网在线播放| 欧美极品aⅴ影院| 激情久久五月天| 亚洲精品一区二区三区影院| 免费在线视频一区| 337p亚洲精品色噜噜狠狠| 亚洲成人精品在线观看| 欧美高清你懂得| 天天色 色综合| 日韩一级高清毛片| 免费人成网站在线观看欧美高清| 欧美日韩极品在线观看一区| 亚洲高清中文字幕| 欧美精品v国产精品v日韩精品| 亚洲mv在线观看| 91精品国产综合久久精品麻豆| 午夜欧美大尺度福利影院在线看| 欧美日韩在线亚洲一区蜜芽| 午夜精品免费在线观看| 91精品国产一区二区人妖| 久久99久久精品欧美| 久久综合九色综合97婷婷女人| 国产一区二区美女| 亚洲国产成人在线| 色网站国产精品| 午夜视频在线观看一区二区三区| 欧美一区二区三区白人| 久久av中文字幕片| 国产精品入口麻豆原神| 91美女在线看| 手机精品视频在线观看| 精品久久久久一区| 99久久精品国产精品久久| 亚洲一二三区不卡| 欧美精品一区二区精品网| 成人av在线一区二区三区| 一区二区理论电影在线观看| 91精品国产综合久久精品性色| 国产精品中文字幕一区二区三区| 亚洲欧洲性图库| 日韩免费观看高清完整版在线观看| 激情五月婷婷综合| 一区二区成人在线| 26uuu亚洲| 欧美日韩在线播放三区四区| 韩国三级在线一区| 亚洲一区二区欧美激情| 精品久久久久一区二区国产| 色噜噜狠狠成人网p站| 美女网站色91| 一区二区免费视频| 欧美国产禁国产网站cc| 91麻豆精品国产91久久久久久久久| 福利91精品一区二区三区| 亚洲国产中文字幕在线视频综合| 久久综合99re88久久爱| 这里是久久伊人| 91麻豆国产香蕉久久精品| 国产真实精品久久二三区| 午夜精品久久久久久久| 亚洲欧美日韩国产另类专区| 2024国产精品视频| 欧美一区三区四区| 在线观看亚洲成人| av一区二区三区在线| 国产在线播放一区| 日本不卡123| 天天影视色香欲综合网老头| 一区二区三区在线播| 国产精品你懂的| 国产午夜精品一区二区三区嫩草| 欧美伦理影视网| 欧美日韩高清不卡| 欧美三级电影精品| 91福利在线免费观看| 不卡视频免费播放| 国产ts人妖一区二区| 国产在线日韩欧美| 激情综合色丁香一区二区| 石原莉奈在线亚洲二区| 午夜免费欧美电影| 午夜精品久久久久久久久 | 久久99国产乱子伦精品免费| 亚洲午夜久久久| 亚洲一区二区三区在线播放| 国产精品激情偷乱一区二区∴| 国产欧美日韩三级| 国产精品久久久99| 亚洲日本欧美天堂| 亚洲国产精品久久久男人的天堂| 亚洲gay无套男同| 午夜久久福利影院| 麻豆成人免费电影| 国产精品一级片在线观看| 国产成人在线视频网站| 成人高清在线视频| 日本高清不卡aⅴ免费网站| 欧美写真视频网站| 91精品福利在线一区二区三区| 欧美mv和日韩mv的网站| 久久久久国产免费免费| 中文字幕一区二区三| 亚洲最色的网站| 美美哒免费高清在线观看视频一区二区| 婷婷综合另类小说色区| 久久国产视频网| 成人激情开心网| 欧洲一区二区av| 精品久久久久久久久久久院品网| 国产欧美日韩另类视频免费观看 | 日韩一区二区免费视频| 精品电影一区二区| 亚洲欧美偷拍另类a∨色屁股| 亚洲一区二区影院| 激情五月激情综合网| 色婷婷综合久久久久中文| 6080午夜不卡| 国产精品久久国产精麻豆99网站 | 丁香网亚洲国际| 欧美主播一区二区三区美女| 精品国免费一区二区三区| 亚洲欧洲国产日本综合| 日本伊人午夜精品| 不卡影院免费观看| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲午夜av在线| 国产jizzjizz一区二区| 欧美麻豆精品久久久久久| 中文字幕va一区二区三区| 青青青伊人色综合久久| 色综合久久综合中文综合网| 欧美一区二区久久| 亚洲欧美日韩电影| 大白屁股一区二区视频| 这里只有精品视频在线观看| 国产精品国产自产拍高清av王其 | 色8久久精品久久久久久蜜| 精品99999| 麻豆精品久久久| 欧美高清一级片在线|