docker-compose.yml配置文件详解

docker-compose.yml配置文件详解

 

Docker Compose 配置文件详解,转载自博客https://www.jianshu.com/p/2217cfed29d7

先来看一份 docker-compose.yml 文件,不用管这是干嘛的,只是有个格式方便后文解说:

version: '2'
services:
  web:
    image: dockercloud/hello-world
    ports:
      - 8080
    networks:
      - front-tier
      - back-tier

  redis:
    image: redis
    links:
      - web
    networks:
      - back-tier

  lb:
    image: dockercloud/haproxy
    ports:
      - 80:80
    links:
      - web
    networks:
      - front-tier
      - back-tier
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock 

networks:
  front-tier:
    driver: bridge
  back-tier:
    driver: bridge

可以看到一份标准配置文件应该包含 version、services、networks 三大部分,其中最关键的就是 services 和 networks 两个部分,下面先来看 services 的书写规则。


1.image

services:
  web:
    image: hello-world

在 services 标签下的第二级标签是 web,这个名字是用户自己自定义,它就是服务名称。
image 则是指定服务的镜像名称或镜像 ID。如果镜像在本地不存在,Compose 将会尝试拉取这个镜像。
例如下面这些格式都是可以的:

image: redis
image: ubuntu:14.04
image: tutum/influxdb
image: example-registry.com:4000/postgresql
image: a4bc65fd

2.build
服务除了可以基于指定的镜像,还可以基于一份 Dockerfile,在使用 up 启动之时执行构建任务,这个构建标签就是 build,它可以指定 Dockerfile 所在文件夹的路径。Compose 将会利用它自动构建这个镜像,然后使用这个镜像启动服务容器。

build: /path/to/build/dir

也可以是相对路径,只要上下文确定就可以读取到 Dockerfile。

build: ./dir

 

设定上下文根目录,然后以该目录为准指定 Dockerfile。

build:
  context: ../
  dockerfile: path/of/Dockerfile

 

注意 build 都是一个目录,如果你要指定 Dockerfile 文件需要在 build 标签的子级标签中使用 dockerfile 标签指定,如上面的例子。
如果你同时指定了 image 和 build 两个标签,那么 Compose 会构建镜像并且把镜像命名为 image 后面的那个名字。

build: ./dir
image: webapp:tag

既然可以在 docker-compose.yml 中定义构建任务,那么一定少不了 arg 这个标签,就像 Dockerfile 中的 ARG 指令,它可以在构建过程中指定环境变量,但是在构建成功后取消,在 docker-compose.yml 文件中也支持这样的写法:

build:
  context: .
  args:
    buildno: 1
    password: secret

下面这种写法也是支持的,一般来说下面的写法更适合阅读。

build:
  context: .
  args:
    - buildno=1
    - password=secret

与 ENV 不同的是,ARG 是允许空值的。例如:

args:
  - buildno
  - password

这样构建过程可以向它们赋值。

注意:YAML 的布尔值(true, false, yes, no, on, off)必须要使用引号引起来(单引号、双引号均可),否则会当成字符串解析。


3.command
使用 command 可以覆盖容器启动后默认执行的命令。

command: bundle exec thin -p 3000

也可以写成类似 Dockerfile 中的格式:

command: [bundle, exec, thin, -p, 3000]

4.container_name
前面说过 Compose 的容器名称格式是:<项目名称><服务名称><序号>
虽然可以自定义项目名称、服务名称,但是如果你想完全控制容器的命名,可以使用这个标签指定:

container_name: app

 

这样容器的名字就指定为 app 了。


5.depends_on
在使用 Compose 时,最大的好处就是少打启动命令,但是一般项目容器启动的顺序是有要求的,如果直接从上到下启动容器,必然会因为容器依赖问题而启动失败。
例如在没启动数据库容器的时候启动了应用容器,这时候应用容器会因为找不到数据库而退出,为了避免这种情况我们需要加入一个标签,就是 depends_on,这个标签解决了容器的依赖、启动先后的问题。
例如下面容器会先启动 redis 和 db 两个服务,最后才启动 web 服务:

version: '2'
services:
  web:
    build: .
    depends_on:
      - db
      - redis
  redis:
    image: redis
  db:
    image: postgres

注意的是,默认情况下使用 docker-compose up web 这样的方式启动 web 服务时,也会启动 redis 和 db 两个服务,因为在配置文件中定义了依赖关系。


6.dns
和 --dns 参数一样用途,格式如下:

dns: 8.8.8.8

也可以是一个列表:

dns:
  - 8.8.8.8
  - 9.9.9.9

此外 dns_search 的配置也类似:

dns_search: example.com
dns_search:
  - dc1.example.com
  - dc2.example.com

7.tmpfs
挂载临时目录到容器内部,与 run 的参数一样效果:

tmpfs: /run
tmpfs:
  - /run
  - /tmp

8.entrypoint
在 Dockerfile 中有一个指令叫做 ENTRYPOINT 指令,用于指定接入点,第四章有对比过与 CMD 的区别。
在 docker-compose.yml 中可以定义接入点,覆盖 Dockerfile 中的定义:

entrypoint: /code/entrypoint.sh

格式和 Docker 类似,不过还可以写成这样:

entrypoint:
    - php
    - -d
    - zend_extension=/usr/local/lib/php/extensions/no-debug-non-zts-20100525/xdebug.so
    - -d
    - memory_limit=-1
    - vendor/bin/phpunit

9.env_file
还记得前面提到的 .env 文件吧,这个文件可以设置 Compose 的变量。而在 docker-compose.yml 中可以定义一个专门存放变量的文件。
如果通过 docker-compose -f FILE 指定了配置文件,则 env_file 中路径会使用配置文件路径。

如果有变量名称与 environment 指令冲突,则以后者为准。格式如下:

env_file: .env

或者根据 docker-compose.yml 设置多个:

env_file:
  - ./common.env
  - ./apps/web.env
  - /opt/secrets.env

注意的是这里所说的环境变量是对宿主机的 Compose 而言的,如果在配置文件中有 build 操作,这些变量并不会进入构建过程中,如果要在构建中使用变量还是首选前面刚讲的 arg 标签。


10.environment
与上面的 env_file 标签完全不同,反而和 arg 有几分类似,这个标签的作用是设置镜像变量,它可以保存变量到镜像里面,也就是说启动的容器也会包含这些变量设置,这是与 arg 最大的不同。
一般 arg 标签的变量仅用在构建过程中。而 environment 和 Dockerfile 中的 ENV 指令一样会把变量一直保存在镜像、容器中,类似 docker run -e 的效果。

environment:
  RACK_ENV: development
  SHOW: 'true'
  SESSION_SECRET:

environment:
  - RACK_ENV=development
  - SHOW=true
  - SESSION_SECRET

11.expose
这个标签与Dockerfile中的EXPOSE指令一样,用于指定暴露的端口,但是只是作为一种参考,实际上docker-compose.yml的端口映射还得ports这样的标签。

expose:
 - "3000"
 - "8000"

12.external_links
在使用Docker过程中,我们会有许多单独使用docker run启动的容器,为了使Compose能够连接这些不在docker-compose.yml中定义的容器,我们需要一个特殊的标签,就是external_links,它可以让Compose项目里面的容器连接到那些项目配置外部的容器(前提是外部容器中必须至少有一个容器是连接到与项目内的服务的同一个网络里面)。
格式如下:

external_links:
 - redis_1
 - project_db_1:mysql
 - project_db_1:postgresql

13.extra_hosts
添加主机名的标签,就是往/etc/hosts文件中添加一些记录,与Docker client的–add-host类似:

extra_hosts:
 - "somehost:162.242.195.82"
 - "otherhost:50.31.209.229"

启动之后查看容器内部hosts:

162.242.195.82  somehost
50.31.209.229   otherhost

 

14.labels
向容器添加元数据,和Dockerfile的LABEL指令一个意思,格式如下:

labels:
  com.example.description: "Accounting webapp"
  com.example.department: "Finance"
  com.example.label-with-empty-value: ""
labels:
  - "com.example.description=Accounting webapp"
  - "com.example.department=Finance"
  - "com.example.label-with-empty-value"

15.links
还记得上面的depends_on吧,那个标签解决的是启动顺序问题,这个标签解决的是容器连接问题,与Docker client的–link一样效果,会连接到其它服务中的容器。
格式如下:

links:
 - db
 - db:database
 - redis

使用的别名将会自动在服务容器中的/etc/hosts里创建。例如:

172.12.2.186  db
172.12.2.186  database
172.12.2.187  redis

 

相应的环境变量也将被创建。


16.logging
这个标签用于配置日志服务。格式如下:

logging:
  driver: syslog
  options:
    syslog-address: "tcp://192.168.0.42:123"

默认的driver是json-file。只有json-file和journald可以通过docker-compose logs显示日志,其他方式有其他日志查看方式,但目前Compose不支持。对于可选值可以使用options指定。
有关更多这方面的信息可以阅读官方文档:
https://docs.docker.com/engine/admin/logging/overview/


17.pid

pid: "host"

将PID模式设置为主机PID模式,跟主机系统共享进程命名空间。容器使用这个标签将能够访问和操纵其他容器和宿主机的名称空间。


18.ports
映射端口的标签。
使用HOST:CONTAINER格式或者只是指定容器的端口,宿主机会随机映射端口。

ports:
 - "3000"
 - "8000:8000"
 - "49100:22"
 - "127.0.0.1:8001:8001"

注意:当使用HOST:CONTAINER格式来映射端口时,如果你使用的容器端口小于60你可能会得到错误得结果,因为YAML将会解析xx:yy这种数字格式为60进制。所以建议采用字符串格式。


19.security_opt
为每个容器覆盖默认的标签。简单说来就是管理全部服务的标签。比如设置全部服务的user标签值为USER。

security_opt:
  - label:user:USER
  - label:role:ROLE

20.stop_signal
设置另一个信号来停止容器。在默认情况下使用的是SIGTERM停止容器。设置另一个信号可以使用stop_signal标签。

stop_signal: SIGUSR1


21.volumes
挂载一个目录或者一个已存在的数据卷容器,可以直接使用 [HOST:CONTAINER] 这样的格式,或者使用 [HOST:CONTAINER:ro] 这样的格式,后者对于容器来说,数据卷是只读的,这样可以有效保护宿主机的文件系统。
Compose的数据卷指定路径可以是相对路径,使用 . 或者 … 来指定相对目录。
数据卷的格式可以是下面多种形式:

volumes:
  // 只是指定一个路径,Docker 会自动在创建一个数据卷(这个路径是容器内部的)。
  - /var/lib/mysql

  // 使用绝对路径挂载数据卷
  - /opt/data:/var/lib/mysql

  // 以 Compose 配置文件为中心的相对路径作为数据卷挂载到容器。
  - ./cache:/tmp/cache

  // 使用用户的相对路径(~/ 表示的目录是 /home/<用户目录>/ 或者 /root/)。
  - ~/configs:/etc/configs/:ro

  // 已经存在的命名的数据卷。
  - datavolume:/var/lib/mysql

如果你不使用宿主机的路径,你可以指定一个volume_driver。

volume_driver: mydriver

 


22.volumes_from
从其它容器或者服务挂载数据卷,可选的参数是 :ro或者 :rw,前者表示容器只读,后者表示容器对数据卷是可读可写的。默认情况下是可读可写的。

volumes_from:
  - service_name
  - service_name:ro
  - container:container_name
  - container:container_name:rw

23.cap_add, cap_drop
添加或删除容器的内核功能。详细信息在前面容器章节有讲解,此处不再赘述。

cap_add:
  - ALL

cap_drop:
  - NET_ADMIN
  - SYS_ADMIN

24.cgroup_parent
指定一个容器的父级cgroup。

cgroup_parent: m-executor-abcd

 


25.devices
设备映射列表。与Docker client的–device参数类似。

devices:
  - "/dev/ttyUSB0:/dev/ttyUSB0"

26.extends
这个标签可以扩展另一个服务,扩展内容可以是来自在当前文件,也可以是来自其他文件,相同服务的情况下,后来者会有选择地覆盖原有配置。

extends:
  file: common.yml
  service: webapp

用户可以在任何地方使用这个标签,只要标签内容包含file和service两个值就可以了。file的值可以是相对或者绝对路径,如果不指定file的值,那么Compose会读取当前YML文件的信息。
更多的操作细节在后面的12.3.4小节有介绍。


27.network_mode
网络模式,与Docker client的–net参数类似,只是相对多了一个service:[service name] 的格式。
例如:

network_mode: "bridge"
network_mode: "host"
network_mode: "none"
network_mode: "service:[service name]"
network_mode: "container:[container name/id]"

 

可以指定使用服务或者容器的网络。


28.networks
加入指定网络,格式如下:

services:
  some-service:
    networks:
     - some-network
     - other-network

关于这个标签还有一个特别的子标签aliases,这是一个用来设置服务别名的标签,例如:

services:
  some-service:
    networks:
      some-network:
        aliases:
         - alias1
         - alias3
      other-network:
        aliases:
         - alias2

相同的服务可以在不同的网络有不同的别名。


29.其它
还有这些标签:cpu_shares, cpu_quota, cpuset, domainname, hostname, ipc, mac_address, mem_limit, memswap_limit, privileged, read_only, restart, shm_size, stdin_open, tty, user, working_dir
上面这些都是一个单值的标签,类似于使用docker run的效果。

cpu_shares: 73
cpu_quota: 50000
cpuset: 0,1

user: postgresql
working_dir: /code

domainname: foo.com
hostname: foo
ipc: host
mac_address: 02:42:ac:11:65:43

mem_limit: 1000000000
memswap_limit: 2000000000
privileged: true

restart: always

read_only: true
shm_size: 64M
stdin_open: true
tty: true

关于配置文件的扩展写法会在有空的时候补上,写得太长了。(xз」∠)

<think>好的,我现在需要帮助用户理解docker-compose.yml文件的详细说明和用法。用户之前已经询问过相关的问题,并且我提供的引用材料中有关于docker-compose.yml的配置项说明。不过,我需要确保回答结构清晰,符合用户的要求,同时遵循系统级指令。 首先,我要回忆用户提供的引用内容,特别是引用[2],其中详细列出了docker-compose.yml的各种配置项,比如image、build、ports、volumes等。用户现在需要更深入的格式详解和配置项说明,所以需要将这些信息组织起来,用中文解释每个部分的作用和示例。 接下来,我需要考虑用户可能的实际应用场景。例如,用户可能想要部署一个包含多个服务的应用,比如Web应用和数据库的组合。因此,提供一个实际的示例会很有帮助,比如结合Nginx和MySQL的服务配置,这样用户可以看到各个配置项是如何在真实场景中使用的。 同时,用户的问题中提到要“详细说明和用法”,所以我需要分章节来组织内容,比如基本结构、核心配置项、进阶配置、示例分析等。每个部分下再细分具体配置项,用列表或子标题来增强可读性。 另外,根据系统指令,所有行内数学表达式要用$...$,但在这里可能不太涉及数学公式,但需要确保代码块和示例的正确格式。例如,docker-compose.yml的代码块应该用正确的缩进和语法展示,可能使用三个反引号包围,并标明语言类型,比如yaml。 还需要注意用户提到的“生成相关问题”,所以在回答的最后要添加相关问题部分,考虑用户可能进一步询问的内容,比如版本差异、多环境管理、网络配置等。 最后,要检查是否符合所有系统级指令:正确的中文回答、引用标识、代码格式正确、结构清晰。同时,确保引用[1]和[2]在适当的位置标注,例如在提到volumes或networks时,引用[2]中的说明。 现在开始组织内容: 1. 引言:简要介绍docker-compose.yml的作用和重要性,引用[1]提到docker-compose用于容器编排。 2. 文件结构:说明YAML格式的基本要求,比如缩进、键值对,并给出一个基本框架示例。 3. 核心配置项:分点解释version、services下的各个子项(image、build、ports等),每个配置项给出定义、示例和注意事项。这里引用[2]中的详细说明,如image、build、ports等部分。 4. 数据管理:详细说明volumes和networks,如何定义和使用,参考引用[2]中的volumes和networks部分,给出示例。 5. 进阶配置:如环境变量、依赖关系、重启策略等,同样引用[2]中的environment、depends_on、restart等。 6. 完整示例:结合Nginx和MySQL的示例,展示多服务配置,并解释各部分的作用,帮助用户理解实际应用。 7. 常见问题或注意事项:比如版本兼容性、命令覆盖等,可能引用[2]中的command配置项说明。 8. 相关问题:生成三个相关问题,覆盖版本差异、多环境配置、网络配置等用户可能后续提问的方向。 在写作过程中,要确保每个配置项都有清晰的解释和示例,代码块正确使用三个反引号,并且引用标注自然,比如在解释volumes时添加[^2]。同时避免使用Markdown格式,但根据用户提供的示例,可能需要使用代码块和列表,但根据系统指令,用户可见层可能需要结构清晰,所以合理使用标题和分段。 最后检查是否遗漏了重要的配置项,比如container_name、restart策略等,确保覆盖引用[2]中提到的所有关键点,同时保持回答的连贯性和易读性。</think>### Docker Compose.yml 文件详解及配置指南 Docker Compose 是用于定义和运行多容器 Docker 应用的核心工具,其核心配置文件 `docker-compose.yml` 采用 YAML 格式编写。以下为详细说明: --- #### 一、文件基本结构 ```yaml version: "3.8" # 指定语法版本[^2] services: # 定义服务列表 web: # 服务名称 image: nginx:latest # 使用镜像 ports: - "80:80" volumes: # 数据卷定义 db_data: networks: # 网络定义 webnet: ``` --- #### 二、核心配置项说明 1. **服务定义(services)** - **`image`** 指定容器使用的镜像及标签。 示例:`image: mysql:8.0` - **`build`** 通过 Dockerfile 构建镜像,需指定上下文路径。 示例:`build: ./app`(构建 `./app` 目录下的 Dockerfile)[^2] - **`ports`** 端口映射规则,格式为 `主机端口:容器端口`。 示例:`- "8080:80"`(将主机 8080 映射到容器 80 端口)[^2] - **`volumes`** 目录挂载或数据卷绑定,支持持久化存储。 示例:`- ./data:/var/lib/mysql`(挂载主机目录到容器)[^2] - **`environment`** 设置容器环境变量,支持键值对或列表形式。 示例: ```yaml environment: MYSQL_ROOT_PASSWORD: password ``` 2. **网络配置(networks)** 创建自定义网络以实现服务间隔离通信。 示例: ```yaml networks: backend: driver: bridge # 指定网络驱动类型[^2] ``` 3. **数据卷管理(volumes)** 声明独立于容器的数据存储卷。 示例: ```yaml volumes: db_data: # 创建名为 db_data 的卷 ``` --- #### 三、进阶配置项 - **`depends_on`** 定义服务启动依赖顺序。 示例:`depends_on: - db`(确保数据库服务先启动) - **`restart`** 容器重启策略,可选值:`no`, `always`, `on-failure`。 示例:`restart: unless-stopped`[^2] - **`command`** 覆盖 Dockerfile 中的默认启动命令。 示例:`command: ["python", "app.py"]`[^2] - **`container_name`** 自定义容器名称,避免随机命名。 示例:`container_name: my_nginx`[^2] --- #### 四、完整应用示例 ```yaml version: "3.8" services: web: build: . ports: - "5000:5000" volumes: - .:/code depends_on: - redis redis: image: "redis:alpine" volumes: - redis_data:/data volumes: redis_data: ``` **说明**: 1. `web` 服务通过本地 Dockerfile 构建镜像,映射端口 5000,挂载代码目录,并依赖 Redis 服务 2. `redis` 使用 Alpine 版本镜像,挂载独立数据卷 `redis_data` 实现数据持久化[^2] --- #### 五、注意事项 1. YAML 对缩进敏感,必须使用空格(**禁止 Tab 缩进**) 2. `version` 字段需与 Docker 引擎版本兼容 3. 多环境建议通过 `docker-compose.override.yml` 扩展配置 ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值