亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解docker compose 用法

 更新時間:2020年10月26日 08:37:45   作者:返回主頁西北偏北UP  
這篇文章主要介紹了docker compose 用法,本文通過實例代碼演示給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

docker compose的使用場景

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

一個基本的demo演示

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

找一個目錄,在其中創(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,有點像java中的maven pom文件。上述代碼使用的組件有flask和redis。所以requirements.txt文件內容為

flask
redis

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

Dockerfile用來將我們的程序構建成一個docker 鏡像,即docker image。一般Dockerfile中會定義我們的代碼運行的基本環(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文件

上述幾步完成后,我們得到了我們服務本身的docker化執(zhí)行的能力。但該服務依賴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服務直接使用現(xiàn)成的image redis:alpine,沒有指定端口,將暴露redis的默認端口

基礎運維

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

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

在docker-compose.yml所在的目錄,使用命令docker-compose up即可。但該命令在console關閉時,對應的docker service也會被關閉??梢允鞘褂?code>docker-compose up -d 以后臺detach模式去執(zhí)行。

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/tcp
docker_compose_learn_web_1     flask run                        Up      0.0.0.0:5000->5000/tcp

服務前綴docker_compose_learn是當前項目的名稱。項目名稱可以通過環(huán)境變量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數(shù)據

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

docker-compose down --volumes

該命令并不會刪除掛載的宿主操作系統(tǒ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 啟動所有的的服務,并對外暴露端口
docker-compose run需要指定特定的服務進行啟動,比如docker-compose run web bash只會啟動compolse文件中的web服務和其依賴的service,并且不會對外暴露端口,以免跟docker-compose up啟動的服務端口沖突。
docker-compose run僅用在臨時啟動某個服務定位問題的場景

一些擴展知識點

環(huán)境變量

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

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

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

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

  • 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中執(zhí)行

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

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

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

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

通過env_file文件設置

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

TAG=dev

如果環(huán)境變量的名字不為.env或不在當前命令執(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

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

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

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

docker-compose run web env

項目名設定

一個compose對應的一組服務有一個公用的項目名(project name), 它會體現(xiàn)在compose服務的容器名前綴中,網絡前綴中。
項目名稱可以通過環(huán)境變量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:
  - 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"

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

多service的執(zhí)行順序

一個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: postgres

docker compose的安裝

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

docker compose和docker stack的異同

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

到此這篇關于docker compose 用法的文章就介紹到這了,更多相關docker compose 用法內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • docker默認存儲路徑修改方法總結

    docker默認存儲路徑修改方法總結

    docker默認存儲路徑是/var/lib/docker,占用服務器根分區(qū),容易導致磁盤空間占滿,下面這篇文章主要給大家介紹了關于docker默認存儲路徑修改方法的相關資料,需要的朋友可以參考下
    2023-10-10
  • .NETCore Docker實現(xiàn)容器化與私有鏡像倉庫管理

    .NETCore Docker實現(xiàn)容器化與私有鏡像倉庫管理

    Docker是用Go語言編寫基于Linux操作系統(tǒng)的一些特性開發(fā)的,其提供了操作系統(tǒng)級別的抽象,是一種容器管理技術,它隔離了應用程序對基礎架構(操作系統(tǒng)等)的依賴。這篇文章主要介紹了.NETCore Docker實現(xiàn)容器化與私有鏡像倉庫管理,需要的朋友可以參考下
    2019-08-08
  • Docker搭建私有倉庫之Harbor的步驟

    Docker搭建私有倉庫之Harbor的步驟

    這篇文章主要介紹了Docker搭建私有倉庫之Harbor的步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • Docker基礎教程之Dockerfile語法詳解

    Docker基礎教程之Dockerfile語法詳解

    這篇文章主要給大家介紹了關于Docker基礎教程之Dockerfile語法的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Docker具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-07-07
  • docker 容器上編譯 go 程序提示找不到文件問題

    docker 容器上編譯 go 程序提示找不到文件問題

    這篇文章主要介紹了docker 容器上編譯 go 程序無法運行提示找不到文件問題,解決方法也很簡單,感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-05-05
  • Docker 容器虛擬化的實用技巧總結

    Docker 容器虛擬化的實用技巧總結

    這篇文章主要介紹了Docker 容器虛擬化的實用技巧總結的相關資料,需要的朋友可以參考下
    2016-10-10
  • Docker 刪除及清理鏡像的方法

    Docker 刪除及清理鏡像的方法

    本文主要介紹了Docker 刪除及清理鏡像的方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • docker compose 一鍵部署分布式配置中心Apollo的過程詳解

    docker compose 一鍵部署分布式配置中心Apollo的過程詳解

    這篇文章主要介紹了docker compose 一鍵部署分布式配置中心Apollo,今天我們使用Docker來進行搭建,畢竟Docker對于開發(fā)者來說更友好一些,需要的朋友可以參考下
    2021-09-09
  • docker中的run/cmd/entrypoint的區(qū)別詳解

    docker中的run/cmd/entrypoint的區(qū)別詳解

    Dockerfile中run、cmd和entrypoint都能夠用于執(zhí)行命令,針對每個命令給他介紹詳細用途,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-08-08
  • Docker安裝基礎鏡像服務的步驟

    Docker安裝基礎鏡像服務的步驟

    外部機器不能直接訪問容器,網是不通的,但可以訪問宿主機,只要將容器的端口與宿主機進行映射后,訪問宿主機的端口就相當于訪問了容器的端口,本文介紹Docker如何安裝基礎鏡像服務,感興趣的朋友一起看看吧
    2024-01-01

最新評論