随着开发者对Docker了解的深入,使用其进行分布式部署变得复杂。开发者需要在开发,测试以及生产环境中的可移植应用,这些应用需要在不同的平台提供商之间迁移,比如在不同的云平台或者私有数据中心部署,同时,应用应该是可组合的,一个应用可以分解为多个服务。 Docker公司在2014年12月发布了三款用于解决多容器分布式软件可移植部署的问题。

Docker Machine为本地,私有数据中心及公有云平台提供Docker引擎,实现从零到Docker的一键部署。

Docker Compose是一个编排多容器分布式部署的工具,提供命令集管理容器化应用的完整开发周期,包括服务构建,启动和停止。

Docker Swarm为Docker容器提供了原生的集群,它将多个Docker引擎的资源汇聚在一起,并提供Docker标准的API,使Docker可以轻松扩展到多台主机。

Compose是用来编排和管理多容器应用的工具,使用它,你可以通过定义一个YAML文件来定义你的应用的所有服务,然后通过一条命令,你就可以创建并启动所有的服务。

使用Compose仅需要三步: 
- 使用Dockerfile定义你的应用依赖的镜像; 
- 使用docker-compose.yml定义你的应用(APP)具有的服务; 
- 通过docker-compose up命令创建并运行应用;

Compose的特性

  1. 将单个主机隔离成多个环境; 
    Compose使用项目名称(project name)将不同应用的环境隔离开,项目名称可以用来: 

    • 在开发机上,将应用环境复制多份;

    • 防止使用了相同名称服务的应用之间互相干扰;

默认情况下,项目名称是项目文件夹根目录的名称,你可以使用-p标识或COMPOSE_PROJECT_NAME改变默认的名称。

  1. 保护卷中的数据; 
    Compose保护服务使用的所有卷(vloumes),当运行docker-compose run命令时,如果Compose发现存在之前运行过的容器,它会把旧容器中的数据卷拷贝到新的容器中,这保证了你在卷中创建的任何数据都不丢失。

  2. 只重新创建改变过的容器; 
    Compose会缓存用于创建容器的配置信息,当你重启服务时,如果服务没有被更改,Compose就会重用已经存在的容器,这无疑加快了修改应用的速度;

Compose 文件是一个YAML文件,用于定义servicesnetwordvolumes。 Compose 文件的默认路径为./docker-compose.yml(后缀为.yml和.yaml都可以)。

一个service配置将会应用到容器的启动中,很像将命令行参数传递给docker run。 同样,network和volume定义类似于docker network createdocker volume create。 与Docker运行一样,默认情况下尊重Dockerfile中指定的选项(例如CMDEXPOSEVOLUMEENV) - 您不需要在docker-compose.yml中再次指定它们。

docker-Compose 配置命令参考https://deepzz.com/post/docker-compose-file.html

docker-Compose 实际例子参考http://blog.csdn.net/vchy_zhao/article/details/70238413