Docker Compose是定义和运行多容器 Docker 应用程序的工具。使用"Compose",您可以使用 YAML 文件来配置应用程序的服务。然后,使用单个命令,从配置创建并启动所有服务
使用Compose基本上是一个三步过程:
- 使用 定义应用的环境,以便可以在任何地方重现。
Dockerfile
- 定义组成应用的服务,以便它们可以在隔离的环境中一起运行。
docker-compose.yml
- 运行和撰写启动并运行整个应用。
docker-compose up
官方给出了一个标准的 docker-compose.yml
version: '2.0'
services:
web:
build: .
ports:
- "5000:5000"
volumes:
- .:/code
- logvolume01:/var/log
links:
- redis
redis:
image: redis
volumes:
logvolume01: {}
"Compose"的文件格式有多种版本:1、2、2.x 和 3.x,每个版本所支持的docker程序有所不同:
Compose 文件版本 | Docker 发布版本 |
---|---|
3.7 | 18.06.0+ |
3.6 | 18.02.0+ |
3.5 | 17.12.0+ |
3.4 | 17.09.0+ |
3.3 | 17.06.0+ |
3.2 | 17.04.0+ |
3.1 | 1.13.1+ |
3.0 | 1.13.0+ |
2.4 | 17.12.0+ |
2.3 | 17.06.0+ |
2.2 | 1.13.0+ |
2.1 | 1.12.0+ |
2.0 | 1.10.0+ |
1.0 | 1.9.1.+ |
在生成镜像时应用的配置选项。
build可以指定为包含生成上下文路径的字符串:
version: "3.7"
services:
webapp:
build: ./dir
或者,作为在上下文中指定的路径和可选的 Dockerfile以及args的对象:
英文解释:
context: 语境
Dockerfile-alternate: Dockerfile的替代(自己定义的Dockerfile)
args: [我的理解]:传入参数
version: "3.7"
services:
webapp:
build:
context: ./dir
dockerfile: Dockerfile-alternate
args:
buildno: 1
如果你想要指定其他的,Compose 可以使用这些来命名已经建立的镜像:image build webapp tag image
build: ./dir
image: webapp:tag
这导致镜像被命名和标记,该图像是从webapp tag ./dir构建的
注意:在以(版本3)Compose文件以群集模式部署堆栈时,将忽略此选项。该命令仅接受预构建的镜像。
docker stack
包含Dockerfile的目录的路径,或者git存储库的URL。
当提供的值是相对路径时,它将被解释为相对于Compose文件的位置。该目录同样被发送到Docker守护程序来构建上下文。 Compose用生成的名称构建并标记它,然后使用该镜像。
build:
context: ./dir
备用的Dockerfile
Compose使用一个备用文件进行构建。因此还必须指定一个构建路径。
build:
context: .
dockerfile: Dockerfile-alternate
添加构建参数,这是只能在构建过程中访问的环境变量。
首先,在Dockerfile中指定参数:
ARG buildno
ARG gitcommithash
RUN echo "Build number: $buildno"
RUN echo "Based on commit: $gitcommithash"
然后再键入指定参数。您可以传递映射或列表:build
build:
context: .
args:
buildno: 1
gitcommithash: cdc3b19
build:
context: .
args:
- buildno=1
- gitcommithash=cdc3b19
注意:在Dockerfile中,如果您在指令前指定,则在下方的构建指令中不可用。如果您需要一个参数在两个地方都可用,请在说明中也指定它。有关用法的详细信息,请参阅了解ARGS和FROM之间的交互方式。
ARG FROM ARG FROM FROM
您可以在指定构建参数时忽略该值,在这种情况下,构建时的值就是运行Compose的环境中的值。
args:
- buildno
- gitcommithash
注意:YAML布尔值 (, , , , , )必须用引号引起来,以便解析器将它们解释为字符串 true false yes no on off
引擎用于缓存解析的镜像列表。
build:
context: .
cache_from:
- alpine:latest
- corp/web_app:3.14
注意:此选项是v3.2中的新增功能
使用Docker标签将元数据添加到生成的图像中。可以使用数组或字典。建议使用反向DNS表示法,以防止标签与其他软件使用的标签冲突。
build:
context: .
labels:
com.example.description: "Accounting webapp"
com.example.department: "Finance"
com.example.label-with-empty-value: ""
build:
context: .
labels:
- "com.example.description=Accounting webapp"
- "com.example.department=Finance"
- "com.example.label-with-empty-value"
注意:此选项是v3.3中的新增功能
设置此构建容器的分区大小。指定数据为表示字节数的整数值或表示字节值的字符串
/dev/shm
build:
context: .
shm_size: '2gb'
build:
context: .
shm_size: 10000000
在3.5版文件格式添加
建立内部定义的指定阶段
Dockerfile
。有关详细信息,请参见多阶段构建文档。
build:
context: .
target: prod
在3.4版文件格式添加
其他功能用的到我再继续更新,当然想让我提前更新,可以留言(翻译真的烧脑子)
原文:https://www.cnblogs.com/HenryZeng/p/12493952.html