Docker-compose是docker官方的开源项目,通过使用模版yaml文件,实现对docker容器集群的管理。具体教程可以通过官方地址进行实践。Docker-compose主要有两个重要的概念:服务(service)和项目(project),service定义了多个容器,组成了完整的project。


一.Docker-compose与docker的版本


目前docker-compose文件格式有3个版本,分别为1, 2.x 和 3.x分别对应了不同的docker版本,使用yaml文件时需要正确引用。


二.多个-f参数用法

通过-f选项指定一个其它名称的配置文件,比如:


1

docker-compose -f docker-compose-dev.yml up

但如果添加多个-f选项,docker-compose会自动合并,当然也会根据先后顺序把一些重复的配置项覆盖掉。


三.别名使用


参数links用法是链接到其它服务中的容器, 该选项是docker历史遗留的选项, 目前已经可以被aliases网络别名标签功能代替。并且如果service在同一个network中,即使不用links也可以通过容器名称进行通信,亲测过即使使用了links也未曾在/etc/hosts中发现对应的配置,猜测应该是docker-compose对网络进行了优化吧。


补充:


在自定义networks中声明的网络名称,会自动生成folder_my-network容器网络,而并非自定义的my-network名称,也就是会和docker-compose的yaml文件目录有关。


四.使用已经存在的网络

Docker-compose中的网络配置都是默认新建属于自己的专属网络,如果要使用已经存在的网络,需要在yaml文件network配置项中单独说明


1

networks:

2

  default:

3

     external:

4

        name: leo_zhou

使用leo_zhou这个已经存在的网络。


五.关于变量的使用

docker-compose中涉及到变量有两个参数,一个是environment和env_file,用法比较特殊,需要特别的注意!

1.env_file有两种用法,一种是默认的.env配置文件,使用docker-compose文件时会自动加载其中的配置项,实时更新并且是可以作为整个docker-compose的全局变量传入参数;还有一种用法是使用自定义的env配置文件,但作用域仅限与environment参数之中的变量,并且使用自定义的env配置文件时,命令docker-compose config会出现“WARNING: The XXX variable is not set. Defaulting to a blank string.”的错误,自定义的env配置文件是为了补充environment的配置项的可读性,但不建议测试时使用。

2.参数传入也有优先级:

①在docker-compose文件固定写好的参数优先级最高

②使用shell命令export引入参数

③使用.env默认的配置文件引入参数

④使用自定义的env文件引入参数

⑤默认为null的参数

3.environment仅作为docker run -e运行时传入的参数,与env_file用法不一样,并非为修改docker-compose文件设计。


最后补充关于WordPress和MySQL的典型yaml文件,仅作为参考:

.env配置文件


WordPress+MySQL搭建


1

version: '3'

2

services:

3

    wordpress:

4

            image: wordpress

5

            ports:

6

                - '${PORT}:80'

7

            environment:

8

                WORDPRESS_DB_HOST: mysql

9

                WORDPRESS_DB_PASSWORD: 123456

10

            networks:

11

                - leo-bridge

12

            container_name: wordpress

13

            depends_on:

14

                - mysql

15

    mysql:

16

            image: mysql:5.7.21

17

            privileged: true

18

            environment:

19

                MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}

20

            networks:

21

                - leo-bridge

22

            container_name: mysql

23

            volumes:

24

                - /data/mysql:/var/lib/mysql

25

networks:

26

    leo-bridge:

27

      driver: bridge

 如果使用了aliases标签,yaml需要重新配置:


1

version: '3'

2

services:

3

    wordpress:

4

            image: wordpress

5

            ports:

6

                - '${PORT}:80'

7

            environment:

8

                WORDPRESS_DB_HOST: mysql

9

                WORDPRESS_DB_PASSWORD: 123456

10

            networks:

11

               leo-bridge:

12

                    aliases:

13

                      - yw_wordpress

14

            container_name: wordpress

15

            depends_on:

16

                - mysql

17

    mysql:

18

            image: mysql:5.7.21

19

            privileged: true

20

            environment:

21

                MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}

22

            networks:

23

               leo-bridge:

24

                    aliases:

25

                      - yw_mysql

26

            container_name: mysql

27

            volumes:

28

                - /data/mysql:/var/lib/mysql

29

networks:

30

    leo-bridge:

31

      driver: bridge

作者:Leo_zhou

一个练习时长八年半的运维工程师