原文链接:http://www.jianshu.com/p/46cbc44ff1c6
文章目录
1. docker-compose是什么
Docker Compose 是 Docker 官方编排(Orchestration)项目之一,负责快速的部署分布式应用。
2. 概述
Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排。从功能上看,跟 OpenStack 中的 Heat 十分类似。
其代码目前在 https://github.com/docker/compose 上开源。
Compose 定位是 「定义和运行多个 Docker 容器的应用(Defining and running multi-container Docker applications)」,其前身是开源项目 Fig。
通过第一部分中的介绍,我们知道使用一个 Dockerfile 模板文件,可以让用户很方便的定义一个单独的应用容器。然而,在日常工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个 Web 项目,除了 Web 服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。
Compose 恰好满足了这样的需求。它允许用户通过一个单独的 docker-compose.yml 模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。
Compose 中有两个重要的概念:
- 服务 (service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。
- 项目 (project):由一组关联的应用容器组成的一个完整业务单元,在 docker-compose.yml 文件中定义。
Compose 的默认管理对象是项目,通过子命令对项目中的一组容器进行便捷地生命周期管理。Compose 项目由 Python 编写,实现上调用了 Docker 服务提供的 API 来对容器进行管理。因此,只要所操作的平台支持 Docker API,就可以在其上利用 Compose 来进行编排管理。
3. docker-compose安装(centos7)
docker-compose的安装这块不在赘述了,请阅读博友文章:https://www.cnblogs.com/morang/p/9501223.html
curl -L https://get.daocloud.io/docker/compose/releases/download/1.24.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
#验证测试
使用docker-compose --version进行测试,如下输出则说明安装成功:
[root@shell_test ~]# docker-compose --version
docker-compose version 1.24.0, build 0aa59064
4. docker-compose安装(centos6)
#官网下载github二进制包
https://github.com/docker/compose/releases
#重命名
mv docker-compose-Linux-x86_64 /usr/loca/lib/docker-compose
#赋权限
chmod +x /usr/loca/lib/docker-compose
#执行docker-compose报错:解决/lib64/libc.so.6: version `GLIBC_2.14' not found
报错glibc2.12版本太低,centos6.5里的glibc版本太低,需要安装glibc2.17
#下载glibc2.17 rpm包,也可以使用源码编译,但是太复杂,也有可能报错,所以最好是使用rpm包安装
#安装包下载地址:https://copr-be.cloud.fedoraproject.org/results/mosquito/myrepo-el6/epel-6-i386/glibc-2.17-55.fc20/
#将rpm包上传至服务器已有目录,并在目录执行 rpm -Uvh --force --nodeps *.rpm命令进行安装
#验证:
[root@al-bj-web-www07 ~]# strings /lib64/libc.so.6 |grep GLIBC
GLIBC_2.2.5
GLIBC_2.2.6
GLIBC_2.3
GLIBC_2.3.2
GLIBC_2.3.3
GLIBC_2.3.4
GLIBC_2.4
GLIBC_2.5
GLIBC_2.6
GLIBC_2.7
GLIBC_2.8
GLIBC_2.9
GLIBC_2.10
GLIBC_2.11
GLIBC_2.12
GLIBC_2.13
GLIBC_2.14
GLIBC_2.15
GLIBC_2.16
GLIBC_2.17
GLIBC_PRIVATE
docker-compose后无报错,证明安装完成。
5. docker-compose的简单实用
docker-compose使用yaml文件进行容器的相关配置
注意docker-compose与主机docker的版本关系:查看官网https://docs.docker.com/compose/compose-file/
#1) 定义一个yaml文件
[root@shell_test ~]# cat /docker/docker-compose.yaml
version: "3" #docker-compose的版本,在官网上查询,此版本须与主机的docker版本相一致
services: #定义一组服务
web1:
image: tomcat #定义容器所使用的镜像
ports:
- "8887:8080" #设置端口转发
web2:
image: tomcat
ports:
- "8886:8080"
#2) 访问验证:
http://192.168.1.6:8887
http://192.168.1.6:8887