Docker-Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排
Docker-Compose将所管理的容器分为三层,分别是工程(project),服务(service)以及容器(container)。Docker-Compose运行目录下的所有文件(docker-compose.yml,extends文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名。一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像,参数,依赖。一个服务当中可包括多个容器实例,Docker-Compose并没有解决负载均衡的问题,因此需要借助其它工具实现服务发现及负载均衡。
Docker-Compose的工程配置文件默认为docker-compose.yml,可通过环境变量COMPOSE_FILE或-f参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。
使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。在工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个Web项目,除了Web服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。
Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。
Docker-Compose项目由Python编写,调用Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API,就可以在其上利用Compose来进行编排管理。
如果你想看中文API,可以看看知乎的这篇文章,个人感觉很不错,不过里面demo比较少,没有基础的话看起来可能比较吃力
这篇文章中有demo,点击即可
linux上面通过curl下载,下载的是一个文件,不是目录,一个二进制文件。注意要放在/usr/local/bin目录下,自动配置环境变量
// 下载 1.25.5这个是版本号,你自己可以改
sudo curl -L https://github.com/docker/compose/releases/download/1.25.5/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
// 给权限
sudo chmod +x /usr/local/bin/docker-compose
// 检测是否安装成功
docker-compose -v
编写我们的第一个docker-compose.yml,如下
version: "3.0"
services:
#使用的服务,这里要指定唯一的名字或者ID等
tomcat:
#镜像是谁,我这里是tomcat:jre8,记得替换了
image: tomcat:jre8
#端口映射是多少
ports:
- 8080:8080
运行一个docker-compose
// 启动这个项目的所有服务 必须保证运行命令的目录存在docker-compose.yml
docker-compose up
编写多个tomcat,tomcat启动的不同,里面的tomcat前面的颜色不一样
version: "3.0"
services:
#使用的服务,这里要指定唯一的名字或者ID等
tomcat:
#镜像是谁,我这里是tomcat:jre8,记得替换了
image: tomcat:jre8
#端口映射是多少
ports:
- 8080:8080
# 这里名字改了ports端口映射也改了就行
tomcat01:
image: tomcat:jre8
ports:
- 8081:8080