摘要:然而,在日常工作中,經常會碰到需要多個容器相互配合來完成某項任務的情況。現在介紹文件的語法及相關配置。使用指令指定文件名。解決容器的依賴啟動先后的問題。當容器停止時,掛載會被移除。其他其他設置如,基本同命令中的格式與功能。
前面的幾篇筆記中,只說明了如何使用單個鏡像和容器。然而,在日常工作中,經常會碰到需要多個容器相互配合來完成某項任務的情況。例如要實現一個 Web 項目,除了 Web 服務容器本身,往往還需要再加上后端的數據庫服務容器,甚至還包括負載均衡容器等。
那容器之間是怎樣通信的呢?多個容器之間的管理、通信也就是所謂的容器編排。容器編排常使用的工具有docker-compose、kubernetes、swarm等。其中docker-compose是面對單機容器編排最常用的工具。
現在介紹docker-compose文件的語法及相關配置。基本配置同docker的run命令中的參數,如CMD、EXPOSE、VOLUME、EVN等等。
一個docker—compose包含多個服務,每個服務都必須通過 image 指令指定鏡像或 build 指令( 需要 Dockerfile) 等來自動構建生成鏡像。
常用配置選項 build指定 Dockerfile 所在文件夾的路徑( 可以是絕對路徑,或者相對 docker-compose.yml 文件的路徑) 。 Compose 將會利用它自動構建這個鏡像,然后使用這個鏡像。
version: "2.0" services: app: build: .
你也可以使用 context 指令指定 Dockerfile 所在文件夾的路徑。
使用 dockerfile 指令指定 Dockerfile 文件名。
使用 arg 指令指定構建鏡像時的變量。
args: - version: 3.0
在構建命令中使用: wget http://www.docker.com/some_so...$version, 構建參數和 ENV 的效果一樣,都是設置環境變量。所不同的是,ARG 所設置的構建環境的環境變量,在將來容器運行時是不會存在這些環境變量的。但是不要因此就使用 ARG 保存密碼之類的信息,因為 docker history 還是可以看到所有值的。
version: "2.0" services: app: build: context: ./dir dockerfile: your_docker_file_name args: arg_name: arg_value
使用 cache_from 指定構建鏡像的緩存
build: context: ./dir cache_from: - img1:tag1 - img2:tag2command
覆蓋容器啟動后默認執行的命令
command: echo "hello world"configs
見 swarm mode
cgroup_parent制定父cgroup組,意味著將繼承該組的資源限制
cgroup_parent: cgroups_1container_name
制定容器名稱
devices指定設備映射關系,即把外設掛載在某個目錄。
devices: - "/dev/ttyUSB1:/dev/ttyUSB0"depends_on
解決容器的依賴、啟動先后的問題。以下例子中會先啟動 redis db 再啟動 web
version: "3" services: web: build: . depends_on: - db - redis redis: image: redis db: image: postgres
注意: web 服務不會等待 redis db 「 完全啟動」 之后才啟動。
env_file從文件中獲取環境變量,可以為多帶帶的文件路徑或列表。
env_file: .env env_file: - ./common.env - ./apps/web.env - /opt/secrets.env
文件中的內容為鍵值對:key=value,每行一條。 如果有變量名稱與 environment 指令沖突,則以后者為準。這里所說的環境變量是對宿主機的 Compose 而言的,如果在配置文件中有 build 操作,這些變量并不會進入構建過程中,如果要在構建中使用變量還是首選前面剛講的 arg 標簽。
environment設置環境變量。你可以使用數組或字典兩種格式。
environment: key: value key: value environment: - key=value - key=value
如果變量名稱或者值中用到 true|false,yes|no 等表達 布爾 含義的詞匯,最好放到引號里,避免 YAML 自動解析某些內容為對應的布爾語義。我們設置的這些環境變量,可以在后面的命令中用到,用法同shell變量,如設置了一個叫VERSION的環境變量,我們可以在entrypoint的命令中使用,如bash echo $VERSION$
expose暴露端口
expose: - 4665 - 8796ports
映射端口,格式 宿主端口:容器端口。
ports: - 5421:5445memory
我們可以限制容器的內存使用
mem_limit: 1G //限制容器的內存使用量最大為1Gextra_hosts
類似 Docker 中的 --add-host 參數,指定額外的 host 名稱映射信息。
extra_hosts: - "googledns:8.8.8.8" - "dockerhub:52.1.157.61"
會在啟動后的服務容器中 /etc/hosts 文件中添加如下兩條條目。
8.8.8.8 googledns 52.1.157.61 dockerhubhealthcheck
通過命令檢查容器是否健康運行
healthcheck: test: ["CMD", "curl", "-f", "http://localhost"] interval: 1m30s timeout: 10s retries: 3image
制定基礎鏡像
links連接其他容器,不推薦使用,但抵不住它方便啊
links: - container1:alias1 - container2:alias2external_links
在使用Docker過程中,我們會有許多多帶帶使用docker run啟動的容器,為了使Compose能夠連接這些不在docker-compose.yml中定義的容器,我們需要一個特殊的標簽,就是external_links,它可以讓Compose項目里面的容器連接到那些項目配置外部的容器(前提是外部容器中必須至少有一個容器是連接到與項目內的服務的同一個網絡里面)。 格式如下:
external_links: - redis_1 - project_db_1:mysql - project_db_1:postgresqlloggins
配置日志選項
logging: driver: syslog options: syslog-address: "tcp://192.168.0.42:133"
目前支持的日志類型有:
syslog
json-file //默認,因此你使用docker inspect container_id 得到的輸出是json格式的
none
options的參數除了syslog-address,還有max-size max-file
options: max-size: "200k" max-file: "10"network_mode
設置網絡模式。使用和 docker run 的 --network 參數一樣的值。
network_mode: "bridge" network_mode: "host" network_mode: "none" network_mode: "service:[service name]" network_mode: "container:[container name/id]"networks
配置容器連接的網絡。
version: "3.0" services: some-service: networks: - network1 - network2 networks: network1: network2volumes
數據卷所掛載路徑設置。可以設置宿主機路徑 (HOST:CONTAINER ) 或加上訪問模式(HOST:CONTAINER:ro )
volumes: - host_dir:container_dir
之后,你在volume中的讀寫操作,本質上都是在host的文件系統進行讀寫的,因此哪怕你最后把容器刪除,你也可以在主機目錄中訪問這些數據,除非你在刪除容器的同時把volume也顯式刪除。我們一般用于存儲需要保證安全性的數據,如數據庫的data目錄
tmp file掛載臨時目錄到容器內部,與 run 的參數一樣效果:
tmpfs: /run tmpfs: - /run - /tmp
為了讓容器能夠訪問數據而不需要永久地寫入數據,可以使用 tmpfs 掛載,該掛載僅存儲在主機的內存中(如果內存不足,則為 swap)。當容器停止時,tmpfs 掛載會被移除。如果提交容器,則不會保存 tmpfs 掛載。
labellabels: - key:value
為生成的鏡像添加描述信息。可以使用inspect查看。
其他其他設置如omainname, entrypoint, hostname, ipc, mac_address, privileged,read_only, shm_size, restart, stdin_open, tty, user, working_dir ,基本同run命令中的格式與功能。如
restart: always
表示當遇到任意退出的時候,都會自動重啟
例子Dockerfile
FROM python:3.6-alpine # 復制代碼到鏡像 ADD . /code # 設置后面的命令的pwd WORKDIR /code # 安裝依賴 RUN pip install redis flask # 運行服務的命令 CMD ["python", "app.py"]
docker-compose.yml
# docker版本 version: "2.0" services: # 一個服務,名字為web web: # 指定從Dockerfile構建,并指定上下文 build: . # 指定端口映射,host_port:container_port ports: - 5000:5000 # 等待redis服務啟動后再啟動web服務 depends_on: - redis_srv # redis服務,基于鏡像redis redis_srv: image: "redis:latest"
運行
docker-compose up --build
docker-compose up:判斷是否已經有目標鏡像web和redis,如果有就啟動;如果沒有,就構建鏡像并啟動容器;如果已經構建但是Dockerfile或者docker-complse.yml發生變化,就重新構建并啟動。“--build”選項表示無論如何都重新構建鏡像。
docker-compose build: 只構建鏡像不運行容器
docker-compose rm -f: 移除當前目錄下docker-compose構建的鏡像
上一節: Docker 筆記(2):Dockerfile
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/27453.html
摘要:使用構建一個創建一個文件夾創建腳本這個腳本使用了和的包,并且啟動了一個服務端口創建構建的由于在的時候,默認會去官方去獲取,國內是無法訪問的,所以這里使用了的鏡像去下載包。 使用docker-compose構建一個python-web app 創建一個文件夾 python-web-app $mkdir python-web-app $cd python-web-app 2.創建pytho...
摘要:時間年月日星期六說明本文部分內容均來自慕課網。必填用于執行命令,當執行完畢后,將產生一個新的文件層。可選指定此鏡像啟動時默認執行命令。可選用于指定需要暴露的網絡端口號。可選向鏡像中掛載一個卷組。 時間:2017年09月16日星期六說明:本文部分內容均來自慕課網。@慕課網:http://www.imooc.com 教學源碼:無 學習源碼:無 第一章:課程簡介 1-1 課程介紹 Docke...
摘要:概述是一個用來定義和運行復雜應用的工具。使用,用戶通過來進行構建。使用,不再需要使用腳本來啟動容器。在配置文件中,所有的容器通過來定義,然后通過腳本來啟動,停止和重啟應用,和應用中的服務以及所有依賴服務的容器。 概述 Docker Compose是一個用來定義和運行復雜應用的Docker工具。使用Compose,你可以在一個文件中定義一個多容器應用,然后使用一條命令來啟動你的應用,完成...
摘要:概述是一個用來定義和運行復雜應用的工具。使用,用戶通過來進行構建。使用,不再需要使用腳本來啟動容器。在配置文件中,所有的容器通過來定義,然后通過腳本來啟動,停止和重啟應用,和應用中的服務以及所有依賴服務的容器。 概述 Docker Compose是一個用來定義和運行復雜應用的Docker工具。使用Compose,你可以在一個文件中定義一個多容器應用,然后使用一條命令來啟動你的應用,完成...
閱讀 2060·2019-08-30 15:52
閱讀 2450·2019-08-29 18:37
閱讀 806·2019-08-29 12:33
閱讀 2850·2019-08-29 11:04
閱讀 1546·2019-08-27 10:57
閱讀 2104·2019-08-26 13:38
閱讀 2772·2019-08-26 12:25
閱讀 2460·2019-08-26 12:23