日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解docker compose 用法

瀏覽:18日期:2024-11-17 14:09:49
docker compose的使用場景

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

一個基本的demo演示

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

找一個目錄,在其中創建一個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)

在相同的文件夾下,創建requirements.txt文件

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

flaskredis

在相同的文件夾下,創建Dockerfile

Dockerfile用來將我們的程序構建成一個docker 鏡像,即docker image。一般Dockerfile中會定義我們的代碼運行的基本環境,程序啟動命令,執行端口等。本例的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']

在相同的文件下,創建docker-compose.yml文件

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

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

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

redis服務直接使用現成的image redis:alpine,沒有指定端口,將暴露redis的默認端口

基礎運維

所有docker-compose相關的命令,都要在docker-compose.yml所在的路徑下執行才行

啟動基于docker-compose.yml編織好的服務

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

docker-compose up 也可以單獨啟動compolse file中的某個服務及其依賴

查看compose服務對應的容器服務列表

docker-compose ps

輸出結果樣例

# 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

服務前綴docker_compose_learn是當前項目的名稱。項目名稱可以通過環境變量COMPOSE_PROJECT_NAME來指定,如果未指定,默認的項目名稱為compose 文件所在文件夾的名字。本例中的文件夾名為docker_compose_learn

當然compose的一系列服務,最終也是啟動了一系列的container. 所以也可使用docker container命令族進行管理,但是太麻煩

停止service的container

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

停止service的container,并且刪除對應的container

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

docker-compose down

停止service的container,并且刪除對應的container和對應的volumes數據

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

docker-compose down --volumes

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

如何登進對應的service

想要登錄到compose中,具體某個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的區別

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

一些擴展知識點

環境變量

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

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

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

除了指定以的變量意外,還有多個docker內置的變量可以設置,他們用來配置docker的或者docker compose的執行行為。這些內置變量是

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為例,講解變量的設置可以有以下幾種方式

在docker-compose.yml中執行

在compolse文件中,通過environment配置項指定

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

在執行docker-compose 命令之前設置shell環境變量

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

通過env_file文件設置

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

TAG=dev

如果環境變量的名字不為.env或不在當前命令執行的路徑下,可以在使用--env-file參數顯示加載

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

以上變量值設置優先級從高到底

查看最終生效的環境變量

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

docker-compose run web env

項目名設定

一個compose對應的一組服務有一個公用的項目名(project name), 它會體現在compose服務的容器名前綴中,網絡前綴中。項目名稱可以通過環境變量COMPOSE_PROJECT_NAME來指定,如果未指定,默認的項目名稱為compose 文件所在文件夾的名字。

網絡

默認網絡

默認情況下,compose中的多個服務會加入一個名為default的網絡。這些服務在default網絡中是互通的。該default網絡的全稱是以compose文件所在文件夾名字做為前綴。比如文件夾為hello_world的compose。其一組服務對應的網絡名為:hello_world_default。 這組service在該網絡中,以compose文件中的第二組端口通信。

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

比如上述配置中,在hello_world_default網絡中,web服務使用8000端口和db服務的5432端口通信。第一組端口8000和8001是宿主機訪問web和db服務的端口。

對默認網絡進行獨立配置

如果想改變默認網絡的配置,可以在compose文件中,單獨通過networks項來改變,比如以下改變默認網絡驅動

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

配置和使用非默認網絡

定義多個網絡,并使用

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'

上述配置定義了兩個網絡,frontend 和 backend。其中app 能訪問這兩個網絡,proxy服務只能訪問frontend網絡,db只能訪問backend網絡

多service的執行順序

一個compose的多個service可能會有依賴關系,比如web服務依賴db服務,我們希望先啟動db服務,再啟動web服務。這種啟動的先后順序,也可以在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版,默認都帶有docker compose 。 只有linux版需要單獨安裝

docker compose和docker stack的異同 docker compose主要目標是在同一臺機器上啟動并管理多個服務 docker stack主要用于在多個機器上,啟動并管理多個服務 docker compose 和docker stack都可以使用docker-compose.yml文件。雙方會自動忽略對自己不生效的配置 docker compose的服務可以使用build動態構建,而docker stack的服務只能基于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

到此這篇關于docker compose 用法的文章就介紹到這了,更多相關docker compose 用法內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Docker
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久精品国产免费| 91日韩在线| 男人操女人的视频在线观看欧美| 亚洲一区二区三区四区五区午夜 | 久久人人88| 樱桃成人精品视频在线播放| 亚洲少妇自拍| 日韩中出av| 亚洲免费福利一区| 欧美日韩xxxx| av日韩中文| 婷婷久久一区| 亚洲乱亚洲高清| 久久只有精品| 91精品韩国| 蜜臀a∨国产成人精品| 国产精品片aa在线观看| 99成人超碰| 欧美日韩中出| 亚洲一区资源| 综合激情一区| 国模大尺度视频一区二区| 欧美va天堂在线| 亚洲精品一级| 国产一区日韩| 麻豆亚洲精品| 国产精品成人一区二区不卡| 日韩一区二区久久| 国产精品v日韩精品v欧美精品网站 | 激情欧美日韩一区| 日本中文字幕不卡| 日韩精品电影| 91欧美日韩在线| 91精品在线观看国产| 中文无码日韩欧| 日本一二区不卡| 亚洲网址在线观看| 性感美女一区二区在线观看| 日韩一区二区三区精品| 在线观看精品| 国产九一精品| 国产精品美女久久久| 精品一二三区| 视频一区视频二区中文| 伊人久久国产| 日韩精品视频一区二区三区| 日韩欧美另类一区二区| 欧美日韩一区二区三区在线电影| 99视频精品全部免费在线视频| 日韩视频一区二区三区在线播放免费观看 | 欧美性www| 欧美天堂亚洲电影院在线观看| 麻豆国产欧美一区二区三区 | 97精品久久| 999在线观看精品免费不卡网站| 欧美激情视频一区二区三区免费 | 日韩综合一区二区| 久久免费黄色| 久久久久伊人| 日韩三级久久| 香蕉久久夜色精品国产| 婷婷综合六月| 久久中文精品| 欧美天堂在线| 亚洲精品美女91| 亚洲欧美视频| 亚洲高清二区| 欧美日韩视频免费观看| 精品资源在线| 日韩精品免费一区二区夜夜嗨| 久久精品av麻豆的观看方式| 亚洲一区免费| 午夜国产精品视频免费体验区| 黄毛片在线观看| 精品在线网站观看| 国产精品久久亚洲不卡| 欧美日韩91| 日本久久一区| 日本伊人午夜精品| 亚洲精品欧美| 亚州精品视频| 日本不卡的三区四区五区| 久久不射中文字幕| 美女国产精品| 伊人久久亚洲影院| 一级欧洲+日本+国产| 九九在线精品| 蜜桃视频欧美| 九色精品91| 免费久久久久久久久| 久久九九精品| 国产综合精品一区| 亚洲特级毛片| 悠悠资源网久久精品| 在线亚洲精品| 亚洲我射av| 日韩高清中文字幕一区| 91精品国产自产在线丝袜啪| 日本精品另类| 日韩激情中文字幕| 日韩精品导航| 欧美91在线|欧美| 麻豆精品在线观看| 中文在线а√在线8| 久久精品在线| 国产亚洲网站| 日韩av一级片| 久久伊人久久| 成人久久久久| 欧美中文日韩| 欧美久久久网站| 精品视频在线一区二区在线| av免费不卡国产观看| 欧美va天堂在线| 国产亚洲一区在线| 日本成人在线视频网站| 久久中文在线| 伊人久久大香线蕉av不卡| 中文日韩在线| 国产欧美日韩影院| 久久国产免费看| 日韩在线短视频| 免费视频一区二区| 久久99久久久精品欧美| 久久久精品午夜少妇| 蜜桃免费网站一区二区三区| 国产精品美女在线观看直播| 在线精品亚洲欧美日韩国产| 性一交一乱一区二区洋洋av| 婷婷亚洲成人| 精品美女久久| 一本一道久久a久久精品蜜桃| 日本不卡视频一二三区| 国产一区二区三区成人欧美日韩在线观看| 久久久久久久久久久9不雅视频| 视频一区国产视频| 精品女同一区二区三区在线观看| 九一成人免费视频| 日本少妇一区二区| 久久精品免费一区二区三区 | 69精品国产久热在线观看| 国产suv精品一区| 免费欧美在线视频| 国产精品黑丝在线播放| 一区二区三区国产在线| 精品免费视频| 亚洲最大av| 日韩av首页| 国产欧美亚洲精品a| 久久国产影院| 国产精品午夜一区二区三区| 午夜国产一区二区| 国产极品嫩模在线观看91精品| 五月天激情综合网| 国产亚洲一区| 自拍日韩欧美| 国产96在线亚洲| 日韩精品成人| 99国产精品| 成人福利av| 欧美日一区二区三区在线观看国产免| 性欧美xxxx免费岛国不卡电影| 国产精品久久久免费| 首页欧美精品中文字幕| 亚洲伦乱视频| 老牛国内精品亚洲成av人片| 亚洲三级精品| 欧美日韩少妇| 欧美sm一区| 国产亚洲久久| 香蕉久久国产| 国产一区清纯| 樱桃视频成人在线观看| 国产精品porn| 日韩影片在线观看| 亚洲欧美不卡| 国产一区欧美| 日韩中文在线播放| 国产精品成久久久久| 国产免费av国片精品草莓男男| 亚洲永久精品唐人导航网址| 2023国产精品久久久精品双| 日韩av首页| 涩涩av在线| 国产精品**亚洲精品| 日本一区二区三区中文字幕| 六月天综合网| 久热re这里精品视频在线6| 91超碰国产精品| 国产91久久精品一区二区| 日韩一区二区中文| 九九色在线视频| 在线手机中文字幕| 四虎国产精品免费观看| 久久精品国产亚洲aⅴ| 久久影视三级福利片| 久久99久久人婷婷精品综合| 国产亚洲久久| 日本视频一区二区| 三级久久三级久久久|