docker-compose日常使用问题汇总(基础篇)

f029935a1e95550f7bfbab1abf9a9e42.png

本文主要参考官方文档对目前最新的V3版docker-compose配置文件进行一个总结。都是一些概念性的内容,不涉及具体操作。

这里主要对docker-compose配置文件的版本的相关要点进行一个简单的总结。至于每个版本具体的变化和升级信息可以参考官方的docker-compose配置文件版本与升级指南。

e95adc3f1ea18e29e09c877d668b0eb5.png

1.docker-compose配置文件格式的版本概述

当前有三种版本的docker-compose配置文件格式:

Version 1:

旧版格式,通过省略YAML的根配置项version来指定。

未声明版本的docker-compose配置文件都被视为V1版,所有的服务都作为根选项在docker-compose配置文件中声明。

支持V1的Compose最高到1.6.x,再高版本的docker-compose不推荐使用V1版docker-compose配置文件。

不支持数据卷、网络和构建参数配置。

V1的docker-compose不会利用网络优势,每个容器都位于默认的bridge网络上,并且可以从其他容器的IP地址访问,需要使用links来启用容器之间的发现。

2359e21820229e5cf16f138452a5e065.png

Version 2.x:

通过YAML的根配置项version来指定,具体配置如version: '2'或version: '2.1'等。

必须在docker-compose配置文件根选项指定版本号,并且主版本数字为2,且所有服务必须在services配置项下声明。

1.6.0+版本的docker-compose都支持V2,Docker Engine的版本需要1.10.0+版本。

支持数据卷和网络的配置。

默认情况下,每个容器都加入了应用范围的默认网络,并且可以在与服务名称相同的主机名下发现。很大程度上links不是必要的。

V2中加入了环境变量替换。

Version 3.x:

最新版本,也是推荐使用版本,推出该版的目的是为了在docker-compose和Docker Engine的swarm模式之间形成交叉兼容。

通过YAML的根配置项version来指定,具体配置如version: '3'或version: '3.1'等。

V3删除了多个配置项,但也新增了更多配置项。

关于docker-compose配置文件版本的常见注意事项:

在声明V2和V3版本时需注意:

在指定docker-compose配置文件要使用的版本时,需同时指定主版本数字和次版本数字。如果未给定次版本数字,则默认使用0而不是最新版本,因此将不支持再更高版本中才加入的新功能。比如version: '3',使用的是3.0版本而不是目前最新的3.9版本。

615582d3e9c52447bdf0c29f11523fd6.png

在使用多docker-compose配置文件时需注意:

使用多个docker-compose配置文件扩展服务时,每个文件必须为相同的版本。

2. docker-compose配置文件格式版本与Docker的兼容性关系

docker-compose配置文件格式具有多种版本。其中docker-compose配置文件格式版本与Docker的兼容性关系如下表所示:

docker-compose配置文件格式版本 Docker Engine版本

Compose配置文件格式版本Docker Engine版本
3.819.03.0+
3.718.06.0+
3.618.02.0+
3.517.12.0+
3.417.09.0+
3.317.06.0+
3.217.04.0+
3.11.13.1+
31.13.0+
2.417.12.0+
2.317.06.0+
2.21.13.0+
2.11.12.0+
21.10.0+
11.9.1.+

如果使用的较旧版本的Docker,可以参考官方的Compose版本发布列表。其中的每组发行说明都详细说明了支持的Docker Engine版本和兼容的Compose配置文件格式版本。

3.兼容模式

在1.20.0版本,docker-compose在docker-compose命令中引入了一个新的选项--compatibility,目的在于帮助开发人员更轻松地过渡到V3版。启用该选项后,docker-compose命令会读取每个服务定义的deploy部分,并尝试将其转换为等效的V2配置项。目前,以下deploy下的配置项已被转换:

resources下的limits和reservations下的memory

replicas

restart_policy下的 condition 和max_attempts

所有的其他配置项都将被忽略,如果这些被忽略的配置项存在则会发出一个警告。可以使用带--compatibility的Config命令查看将用于deploy的配置。

注意请勿在生成环境使用兼容模式!

建议不要在生产环境中使用--compatibility选项。由于使用非Swarm模式属性生成的配置仅是近似值,因此可能会产生意外的结果。

e8c0c88f195742f4d0280650b9c86923.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值