Docker學習—Compose

chaney1992發表於2020-11-08

前言

 前面《Docker學習—DockerFile》文中介紹了dockerfile相關的語法,及使用方式;接下來了解docker三劍客之一的 Compose;接下來詳細學習。

一、docker-compose介紹

 Docker-Compose專案是Docker官方的開源專案,主要使用Python編寫;用於定義和執行多容器Docker應用程式的工具。使用Compose,可以使用YAML檔案來配置應用程式的服務。然後使用一個命令,從配置建立並啟動所有服務。

 Compose是一個定位“定義和執行多個Docker容器應用的工具”,其前身是Fig,目前使用的Compose仍然相容Fig格式的模板檔案。

 Compose中包含兩個重要概念:

  • 服務(Service):一個應用的容器,實際可以包含若干個執行相同映象的容器例項
  • 專案(Project):一組相關聯的應用容器組成的完整業務單元,在docker-compose.yml檔案中定義 

 Compose的預設管理物件是專案,通過子命令對專案中的一組容器進行便捷地生命週期管理。

二、docker-compose安裝

 Compose目前已經完全支援Linux、Mac OS和Windows,在安裝Compose之前,需要先安裝Docker;(本篇主要在window中使用)

 安裝成功後命令列中輸入:docker compose -h  

 

三、docker-compose 命令

 安裝成功後來看下compose主要包含的命令:

  build              #生成或重建服務
  bundle             #從Compose檔案生成Docker bundle
  config             #驗證並檢視撰寫檔案
  create             #建立服務
  down               #停止並刪除容器、網路、映象和卷
  events             #從容器接收實時事件
  exec               #在正在執行的容器中執行命令
  help               #獲取命令幫助
  images             #顯示映象列表
  kill               #殺死容器
  logs               #檢視容器的輸出
  pause              #暫停服務
  port               #列印埠繫結的公共埠
  ps                 #顯示容器列表
  pull               #拉取服務映象
  push               #推送服務映象
  restart            #重新啟動服務
  rm                 #移除停止的容器
  run                #執行一次性命令
  scale              #設定服務的容器數
  start              #啟動服務
  stop               #暫停服務
  top                #顯示正在執行的程式
  unpause            #取消暫停服務
  up                 #建立並啟動容器
  version            #顯示Docker-Compose版本資訊

 對命令有大概印象後,接下來就需要對重點內容(docker-compose.yml)瞭解;每個命令具體的使用引數在使用是具體介紹

三、docker-compose.yml編寫

 docker-compose.yml已有多個版本:如下

  首先我們先來看一個官方示例docker-compose.yml內容:

version: "3.8"
services:

  redis:
    image: redis:alpine
    ports:
      - "6379"
    networks:
      - frontend
    deploy:
      replicas: 2
      update_config:
        parallelism: 2
        delay: 10s
      restart_policy:
        condition: on-failure

  db:
    image: postgres:9.4
    volumes:
      - db-data:/var/lib/postgresql/data
    networks:
      - backend
    deploy:
      placement:
        max_replicas_per_node: 1
        constraints:
          - "node.role==manager"

  vote:
    image: dockersamples/examplevotingapp_vote:before
    ports:
      - "5000:80"
    networks:
      - frontend
    depends_on:
      - redis
    deploy:
      replicas: 2
      update_config:
        parallelism: 2
      restart_policy:
        condition: on-failure

  result:
    image: dockersamples/examplevotingapp_result:before
    ports:
      - "5001:80"
    networks:
      - backend
    depends_on:
      - db
    deploy:
      replicas: 1
      update_config:
        parallelism: 2
        delay: 10s
      restart_policy:
        condition: on-failure

  worker:
    image: dockersamples/examplevotingapp_worker
    networks:
      - frontend
      - backend
    deploy:
      mode: replicated
      replicas: 1
      labels: [APP=VOTING]
      restart_policy:
        condition: on-failure
        delay: 10s
        max_attempts: 3
        window: 120s
      placement:
        constraints:
          - "node.role==manager"

networks:
  frontend:
  backend:

volumes:
  db-data:

 

 根據以上示例格式可以看出docker-compose.yml中主要包含以下內容:

  • version: 指定當前docker-compose.yml的版本,版本與Docker Engine版本存在對應關係,如:v3.8對應 Docker Engine 19.03.0+
  • services:服務,可以定義業務需要的一些服務,每個服務可包含服務名稱、使用映象、掛載資料卷、使用的網路、依賴服務等資訊
  • networks:應用的網路,可以定義網路名稱、使用的網路型別等
  • volumes:資料卷,可以定義資料卷,然後掛載到不同的服務下使用

 接著就來看下相關命令的語法及具體含義

  

docker-compose.yml命令
序號 所屬 命令 說明
1 services build 基於Dockerfile,指定Dockerfile所在路徑,Compose會利用它自動構建映象,然後啟動服務容器 
2 cap_add,cap_drop 新增或刪除容器功能
3 command 覆蓋容器啟動後預設執行的命令
4 config 使用“每服務配置”配置在每個服務的基礎上授予對配置的訪問許可權。存在兩種語法方式:短語法、長語法
5 cgroup_parent 為容器指定一個可選的父cgroup
6 container_name 容器名稱
7 depends_on 容器依賴,用於指定服務依賴的其他服務
8 depoly

指定與服務的部署和執行相關的配置。這隻在使用docker stack deploy部署到一個群時生效,docker compose up和docker compose run將忽略此項。

9 devices 裝置對映列表。
10 dns 自定義DNS伺服器。可以是單個值或列表。
11 dns_search 自定義DNS搜尋域。可以是單個值或列表。
12 entrypoint 覆蓋預設入口點
13 env_file 從檔案新增環境變數。可以是單個值或列表
14 environment 新增環境變數。可以使用陣列或字典。任何布林值(true、false、yes、no)都需要用引號括起來,以確保它們不會被YML解析器轉換為true或false。
15 expose 暴露埠而不將它們釋出到主機-它們只能被連結的服務訪問。只能指定內部埠。
16 external_links 連結到在此範圍之外docker-compose.yml甚至在Compose之外開始的容器,尤其是對於提供共享或公共服務的容器。 同時指定容器名稱和連結別名()時,請external_links遵循與legacy選項相似的語義。
17 extra_hosts 新增主機名對映。使用與docker客戶端相同的值
18 healthcheck 配置執行的檢查以確定該服務的容器是否“健康”
19 image 指定要從中啟動容器的映象。可以是儲存庫/標籤或映象ID
20 init 在容器內執行一個初始化程式,以轉發訊號並獲取程式。設定此選項可以true為服務啟用此功能。 
21 isolation 指定容器的隔離技術。在Linux上,唯一支援的值是default。在Windows中,可接受的值是default,process和 hyperv。
22 labels 使用Docker標籤將後設資料新增到容器中。您可以使用陣列或字典。
23 links 連結到另一個服務中的容器。指定服務名稱和連結別名("SERVICE:ALIAS"),或者僅指定服務名稱。
24 logging 服務的日誌記錄配置
25 network_mode 網路模式。使用與客戶端服務相同的網路名稱和服務-引數docker相同。
26 networks 要加入的網路,引用頂級網路鍵下的條目。
27 pid 將PID模式設定為主機PID模式。這將開啟容器和主機作業系統之間的PID地址空間共享。
28 ports 暴露埠 
29 restart no是預設的重啟策略,在任何情況下都不會重啟容器。當always指定時,容器總是重新啟動。該 on-failure如果退出程式碼指示的故障錯誤政策重啟的容器。unless-stopped總是重新啟動容器,除非容器停止(手動或其他方式)。
30 secrets 使用按服務secrets 配置,按服務授予對機密的訪問許可權。
31 security_opt 覆蓋每個容器的預設標籤方案。
32 stop_grace_period 指定在傳送SIGKILL之前,如果容器不處理SIGTERM(或用stop_nusignal指定的任何停止訊號),嘗試停止該容器時要等待多長時間。預設10s
33 stop_signal 設定停止容器的替代訊號。預設情況下,stop使用SIGTERM。使用stop_signal設定替代訊號會導致stop傳送該訊號。
34 sysctls 要在容器中設定的核心引數。可以使用陣列或字典。
35 tmpfs 在容器內安裝一個臨時檔案系統。可以是單個值或列表。 
36 ulimits 覆蓋容器的預設ulimit。您可以將單個限制指定為整數,也可以將軟/硬限制指定為對映。
37 userns_mode 如果Docker守護程式配置了使用者名稱稱空間,則禁用此服務的使用者名稱稱空間。
38 volumes

掛載主機路徑或命名卷,指定為服務的子選項。可以將主機路徑安裝為單個服務的定義的一部分,而無需在頂級volumes中進行定義。

但是,如果要在多個服務之間重用卷,請在頂級volumes金鑰中定義一個命名卷。

將命名卷與服務,群集和堆疊檔案一起使用。

39

domainname, hostname, ipc, mac_address, privileged,

read_only, shm_size, stdin_open, tty, user, working_dir

其中每個都是一個值,類似於其 docker run對應項。
40 Volumes dirver 指定該卷應使用哪個卷驅動程式。預設為Docker Engine配置為使用的任何驅動程式,大多數情況下為 local。
41 dirver_opts 指定選項列表作為鍵值對,以傳遞給該卷的驅動程式。
42 external 如果設定為true,則指定此卷是在Compose之外建立的。docker-compose up不會嘗試建立它,如果不存在則引發錯誤。
43 labels 使用Docker標籤向容器新增後設資料。可以使用陣列或字典。
44 name 為此卷設定一個自定義名稱。名稱欄位可用於引用包含特殊字元的卷。
45 Networks dirver 指定該網路應使用哪個驅動程式。
46 dirver_opts 指定選項列表作為要傳遞給此網路的驅動程式的鍵值對
47 attachable 僅當驅動程式設定為覆蓋時使用。
48 enable_ipv6 在此網路上啟用IPv6網路。
49 ipam 指定自定義IPAM配置
50 internal 預設情況下,Docker還會連線一個網橋網路來提供外部連線。如果要建立外部隔離的覆蓋網路,可以將此選項設定為true。
51 labels 使用Docker標籤將後設資料新增到容器中 。您可以使用陣列或字典。
52 external 如果設定為true,則指定此網路是在Compose之外建立的。docker-compose up不會嘗試建立它,如果不存在則引發錯誤。
53 name 為此網路設定一個自定義名稱。名稱欄位可用於引用包含特殊字元的網路。

   通過以上內容發現,services中相關命令是docker相關配置項關聯;接下來就來驗證通過docker-compose.yml執行應用 

四、應用案例

 實現效果:基於身份認證時,相關示例程式碼實現,通過docker-compose啟動相關所有服務容器,執行程式。

 A、在解決方案目錄下新增docker-compose.yml檔案:

 新增方式:

 1、手動新增檔案

 2、通過vs自動新增:選中需要新增專案右鍵,如圖

 新增後如下:

 

 

 B、修改內容如下:(該docker-compose.yml比較簡單)

version: '3.4'

services:
  cz.identityserver:
    image: ${DOCKER_REGISTRY-}czidentityserver
    build:
      context: .
      dockerfile: cz.IdentityServer/Dockerfile

  cz.api.order:
    image: ${DOCKER_REGISTRY-}czapiorder
    build:
      context: .
      dockerfile: cz.Api.Order/Dockerfile


  cz.api.goods:
    image: ${DOCKER_REGISTRY-}czapigoods
    build:
      context: .
      dockerfile: cz.Api.Goods/Dockerfile


  cz.mvcclient:
    image: ${DOCKER_REGISTRY-}czmvcclient
    build:
      context: .
      dockerfile: cz.MVCClient/Dockerfile

 

 C、執行命令docker-compose up命令:執行完成看到以下輸出,則編譯啟動完成。

  

  D、在docker管理頁面中檢視如下:

  

後續:

 本篇內容先對docker-compose內容進行了相關介紹,下面將對Swarm、Machine、K8S 進行應用學習。

參考:

  https://docs.docker.com/compose/

  https://docs.docker.com/compose/compose-file/

相關文章