前言:Docker-Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。
文章目录
一、概述
1.Docker-Compose简介
- 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来进行编排管理
2.作用
- Docker Compose 的前身是Fig,它是一个定义及运行多个容器的工具
- 使用Docker Compose不再需要使用shell脚本来启动容器
- 通过Docker Compose可以使用YML文件来配置应用程序所需要的的所有服务
- Docker Compose非常适合组合使用多个容器进行开发的场景
3.关于YML文件
- YAML是一种标记语言很直观的数据序列化格式,非常适合用来表达或者编辑数据结构、各种配置文件、文件大纲等,例如:许多电子邮件标题格式和YAML非常接近
- 文件格式以及编写注意事项
- 不支持制表符tab键缩进,需要使用空格缩进,使用缩进表示层级关
- 通常开头缩进2个空格,缩进的空格数不重要,只要相同层级的元素左对齐即可
- 字符后缩进一个空格,如冒号、逗号、横杆
- 用#号注释
- 如果包含特殊字符用单引号引起来
- 布尔值必须用引号括起来
二、部署
1.使用步骤
- 使用Dockerfile定义应用程序的环境
- 使用docker-compose.yml定义构成应用程序的服务,这样它们可以在隔离环境中一起运行
- 最后执行docker-compose up命令来启动并运行整个应用程序
2.环境部署
- 首先需要部署docker环境,正常关闭防火墙,核心防护,开启路由转发功能以及开启docker
[root@docker-1 ~]# docker version
Client: Docker Engine - Community
Version: 19.03.8
API version: 1.40
Go version: go1.12.17
Git commit: afacb8b
Built: Wed Mar 11 01:27:04 2020
OS/Arch: linux/amd64
Experimental: false
Server: Docker Engine - Community
Engine:
Version: 19.03.8
API version: 1.40 (minimum version 1.12)
Go version: go1.12.17
Git commit: afacb8b
Built: Wed Mar 11 01:25:42 2020
OS/Arch: linux/amd64
Experimental: false
containerd:
Version: 1.2.13
GitCommit: 7ad184331fa3e55e52b890ea95e65ba581ae3429
runc:
Version: 1.0.0-rc10
GitCommit: dc9208a3303feef5b3839f4323d9beb36df0a9dd
docker-init:
Version: 0.18.0
GitCommit: fec3683
- 部署docker-compose环境
[root@docker ~]# curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 638 100 638 0 0 149 0 0:00:04 0:00:04 --:--:-- 149
100 10.3M 100 10.3M 0 0 18758 0 0:09:39 0:09:39 --:--:-- 17256
//在Linux上我们可以从GitHub上下载它的二进制包来使用,此命令是下载Docker Compose的当前稳定版本
[root@docker-1 bin]# chmod +x /usr/bin/docker-compose
[root@docker-1 bin]# docker-compose -v
docker-compose version 1.21.1, build 5a3f1a3
3.部署docker-compose
- 创建一个工作目录以及dockerfile目录
[root@docker-1 ~]# mkdir compose_tomcat
[root@docker-1 ~]# cd compose_tomcat/
[root@docker-1 compose_tomcat]# mkdir tomcat
[root@docker-1 compose_tomcat]# cd tomcat/
- 构建tomcat镜像
[root@docker-1 tomcat]# ls //提前准备好tomcat源码包
apache-tomcat-8.5.16.tar.gz jdk-8u91-linux-x64.tar.gz
[root@docker-1 tomcat]# vim Dockerfile //编写Dockerfile文件
#基于基础镜像
FROM centos:7
#作者信息
MAINTAINER the tomcat
#解压
ADD jdk-8u91-linux-x64.tar.gz /usr/local
#指定目录并添加环境变量
WORKDIR /usr/local
RUN mv jdk1.8.0_91 /usr/local/java
ENV JAVA_HOME /usr/local/java
ENV JAVA_BIN /usr/local/java/bin
ENV JAVA_HOME /usr/local/java/jre
ENV PATH $PATH:/usr/local/java/bin:/usr/local/java/jre/bin
ENV CLASSPATH /usr/local/java/jre/bin:/usr/local/java/lib:/usr/local/java/jre/lib/charsets.jar
#解压并指定目录
ADD apache-tomcat-8.5.16.tar.gz /usr/local
WORKDIR /usr/local
#修改tomcat名称方便管理
RUN mv apache-tomcat-8.5.16 /usr/local/tomcat8
#指定端口
EXPOSE 8080
#启动tomcat
ENTRYPOINT ["/usr/local/tomcat8/bin/catalina.sh","run"]
- 编写YML脚本
[root@docker-1 tomcat]# cd ..
[root@docker-1 compose_tomcat]# ls
tomcat
[root@docker-1 compose_tomcat]# vim docker-compose.yml
version: '3' //声明版本号
services: //服务
tomcat: //服务名称为tomcat
hostname: tomcat //容器的主机名为tomcat
build: //构建容器
context: ./tomcat //素材在tomcat目录下
dockerfile: Dockerfile //dockerfile文件名称
ports: //提供的端口
- 1216:8080
networks: //群集名称为master
- master
networks: //对外公开的群集
master:
[root@docker-1 compose_tomcat]# ls
docker-compose.yml tomcat
- 执行
[root@docker-1 compose_tomcat]# docker-compose -f docker-compose.yml up -d
。。。省略部分内容
Creating compose_tomcat_tomcat_1 ... done
- 查看镜像及容器,可以看到镜像与容器创建成功且容器已经开启,直接访问
[root@promote compose_tomcat]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
compose_tomcat_tomcat latest 935902c47ddf 15 minutes ago 959MB
centos 7 5e35e350aded 5 months ago 203MB
[root@promote compose_tomcat]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
38b9aa330a1d compose_tomcat_tomcat "/usr/local/tomcat8/…" 15 minutes ago Up 15 minutes 0.0.0.0:1234->8080/tcp compose_tomcat_tomcat_1
- 以上便实现了docker-compose的编排,这只是针对了一个服务,下面还可以继续跟其他服务,如nginx等
三、总结
1.YML文件的结构
version: '3' //compose版本号
services: //服务标识符
tomcat: //子服务名
image: dockercloud/hello-world //服务依赖镜像属性
ports: //服务端口属性
- 8080
networks: //网络服务属性
- front-tier
- back-tier
redis:
image: redis
links: //容器间的连接设置
- web
networks:
- back-tier
lb:
image: dockercloud/haproxy
ports:
- 80:80
links:
- web
networks:
- front-tier
- back-tier
volumes: //挂载数据卷容器
- /var/run/docker.sock:/var/run/docker.sock
networks:
front-tier:
driver: bridge
back-tier:
driver: bridge
2.YML文件常用字段
build dockerfile context //指定Dockerfile文件名构建镜像上下文路径
image //指定镜像
command //执行命令,覆盖默认命令
container name //指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale
deploy //指定部署和运行服务相关配置,只能在swarm模式适用
environment //添加环境变量
networks //加入网络
ports //暴露容器端口,与-p相同,但端口不能低于60
volumes //挂载宿主机路径或命令卷
restart //重启策略,默认no,always,no-failure,unless-stoped
hostname //容器主机名
3.Docker-compose常用命令
//docker-compose选项
–verbose:输出更多调试信息
-v(–version):打印版本并退出
-f、–file FILE:使用特定的compose末班文件,默认为docker-compose.yml
-p、–project-name NAME:指定项目名称,默认使用目录名称
build //重新构建服务
ps //列出容器
up //创建和启动容器
exec //在容器里面执行命令
scale //指定一个服务容器启动数量
top //显示容器进程
logs //查看容器输出
down //删除容器、网络、数据卷和镜像
stop/start/restart //停止/启动/重启服务