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选项指定一个其它名称的配置文件,比如:

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配置项中单独说明

networks:
default:
external:
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配置文件

PORT=
MYSQL_ROOT_PASSWORD=

WordPress+MySQL搭建

version: '3'
services:
wordpress:
image: wordpress
ports:
- '${PORT}:80'
environment:
WORDPRESS_DB_HOST: mysql
WORDPRESS_DB_PASSWORD: 123456
networks:
- leo-bridge
container_name: wordpress
depends_on:
- mysql
mysql:
image: mysql:5.7.21
privileged: true
environment:
MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}
networks:
- leo-bridge
container_name: mysql
volumes:
- /data/mysql:/var/lib/mysql
networks:
leo-bridge:
driver: bridge

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

version: ''
services:
wordpress:
image: wordpress
ports:
- '${PORT}:80'
environment:
WORDPRESS_DB_HOST: mysql
WORDPRESS_DB_PASSWORD:
networks:
leo-bridge:
aliases:
- yw_wordpress
container_name: wordpress
depends_on:
- mysql
mysql:
image: mysql:5.7.
privileged: true
environment:
MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}
networks:
leo-bridge:
aliases:
- yw_mysql
container_name: mysql
volumes:
- /data/mysql:/var/lib/mysql
networks:
leo-bridge:
driver: bridge

Docker-compose容易忽略的使用细节的更多相关文章

  1. Docker存储容易忽略的使用细节

    一.Docker容器使用前其实有个非常重要的步骤就是规划好部署的磁盘区域,因为docker容器默认存储的路径是在/var/lib/docker的根目录内,随着使用时间越长部署的内容越多,基本的根目录的 ...

  2. Tensorflow Serving Docker compose 部署服务细节(Ubuntu)

    [摘要] Tensorflow Serving 是tf模型持久化的重要工具,本篇介绍如何通过Docker compose搭建并调试TensorFlow Serving TensorFlow Servi ...

  3. Sentry 监控 - 私有 Docker Compose 部署与故障排除详解

    内容整理自官方开发文档 系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentry-CLI - 30 秒上手 Source Map ...

  4. Docker学习笔记 - Docker Compose 脚本命令

    Docker Compose 配置文件包含 version.services.networks 三大部分,最关键的是 services 和 networks 两个部分, version: '2' se ...

  5. Docker Compose 原理

    Docker 的优势非常明显,尤其是对于开发者来说,它提供了一种全新的软件发布机制.也就是说使用 docker 镜像作为软件产品的载体,使用 docker 容器提供独立的软件运行上下文环境,使用 do ...

  6. [phvia/dkc] Docker Compose 快速构建(LNMP+Node)运行环境

    快速构建(LNMP+Node)运行环境. dkc 在此作为 docker-compose 的缩写,你可以理解为 alias dkc=docker-compose 准备 安装 docker 选择1) 从 ...

  7. Docker Compose(八)

    Docker Compose 是Docker官方编排(Orchstration)项目之一,负责快速在集群中部署分布式应用.   Dockerfile可以让用户管理一个单独的应用容器:而Compose则 ...

  8. 附003.Docker Compose命令详解

    一 Docker Compose命令格式 Usage: docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...] docker- ...

  9. Docker学习笔记之使用 Docker Compose 管理容器

    0x00 概述 通过之前的介绍,我们已经基本掌握了构建.运行容器的方法,但这还远远不够,由于 Docker 采用轻量级容器的设计,每个容器一般只运行一个软件,而目前绝大多数应用系统都绝不是一个软件所能 ...

  10. Docker三剑客之Docker Compose

    一.什么是Docker Compose Compose 项目是Docker官方的开源项目,负责实现Docker容器集群的快速编排,开源代码在https://github.com/docker/comp ...

随机推荐

  1. Windows10关闭自动更新总结

    试过好多关闭windows自动更新的方法,但是在每次重启后发现C盘又塞了一堆更新包,强迫症的我必须要彻底关闭它! 1. services关闭 运行 services.msc ,找到Windows Up ...

  2. 一步一步学会preload和prefetch

    preload和prefetch是什么? 我们常说的preload和prefetch,是link标签rel里新增的两种值,用于让浏览器提前加载指定的资源,它们会先被缓存(属于http cache缓存) ...

  3. python manage.py makemigrat Please select a fix: 1) Provide a one-off default now (will be set on all existing rows with a null value for this column) 2) Quit, and let me add a default in models.py

    更新models字段 出现的问题: $ python manage.py makemigrations None You are trying to add a non-nullable field ...

  4. C语言笔记 09_共用体&typedef&输入|输出

    共用体 共用体允许您在相同的内存位置存储不同的数据类型.您可以定义一个带有多成员的共用体,但是任何时候只能有一个成员带有值.共用体提供了一种使用相同的内存位置的有效方式. 定义共用体 为了定义共用体, ...

  5. 事务日志已满 请参阅sys.databases中的log_reuse_wait_desc列解决办法

    http://www.myexception.cn/sql-server/153219.html http://blog.csdn.net/kedingboy12345/article/details ...

  6. 'com.example.mybatisplus.mapper.PersonMapper' that could not be found.

    通常有两种原因,配置原因,或者是mapper相关文件,mapper.java或 mapper.xml内部错误 如果是配置原因 解决方式1 统一配置mapper //import org.mybatis ...

  7. leetcode解题报告(8):Remove Element

    描述 Given an array and a value, remove all instances of that value in place and return the new length ...

  8. Codeforces Round #571 (Div. 2)

    A. Vus the Cossack and a Contest 签. #include <bits/stdc++.h> using namespace std; int main() { ...

  9. Linux 修改文件夹的用户组权限

    将ubsadm文件夹所属用户修改为userschown -R ubsadm:users /home/ubsadm 此命令将用户123的用户组改为rootusermod -g 123 root

  10. RabbitMQ 和 Kafka 的消息可靠性对比

    RabbitMQ和Kafka都提供持久的消息保证.两者都提供至少一次和至多一次的保证,另外,Kafka在某些限定情况下可以提供精确的一次(exactly-once)保证. 让我们首先理解一下上述术语的 ...