docker-compose + consul
一、前言
Docker Compose的前身时Fig,Fig被Docker收购之后更名为compose,compose向下兼容Fig
Docker compose是一种用于定义和运用多容器Docker应用的工具,只需要一个compose的配置文件和一个简单的命令就可以创建并运行所用所需的所有容器,而不再需要使用shell脚本来启动容器
Docker Compose 非常适合组合使用多个容器进行开发的场景
1.docker compose的文件结构
YAML是一种标记语言很直观放入数据序列化格式,文件格式及编写注意事项如下所示:
- 不支持制表符Tab缩进,需要使用空格缩进
- 通常开头缩进2个空格
- 字符后缩进1个空格,如冒号(😃、逗号(,)、横杆(- )
- 支持用#号注释
- 如果包含特殊字符用单引号引起来
- 布尔值必须用单引号括起来
示例:
house:
family:
name: tom
parent:
- john
- jane
children:
- paul
- mark
address:
number: 34
street:
city: beijing
2.docker compose配置常用字段
字段 | 描述 |
---|---|
version | 指定此yml文件基于的compase的版本 |
services | 指定创建容器的服务选项,服务名:例如nginx等 |
build | 指定构建镜像上下文路径(是一个路径基于docker-compos.yuml文件的所在目录) |
context | 上下文路径 |
dockerfile | 指定构建镜像的 Dockerfile 文件名 |
image | 指定容器运行的镜像 |
command | 执行命令,覆盖默认命令 |
container_name | 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale(扩展,使用副本集) |
deploy | 指定部署和运行服务相关配置,只能在Swarm模式使用 |
environment | 添加环境变量 |
networks | 配置网络,指定网卡设备等(四种网络模式) |
ports | 暴露容器端口,与-p相同,但端口不能低于60;指定端口也不能使用scale |
networks | 配置网络,指定网卡设备等 |
volumes | 挂载宿主机路径或命令卷 |
restart | 重启策略,定义是否重启容器;no(默认,不重启),always(总是重启),no-failure(退出状态非0时重启) |
hostname | 容器主机名 |
3.docker compose常用命令
字段 | 描述 |
---|---|
build | 重新构建服务 |
ps | 列出容器 |
up | 创建和启动容器 |
exec | 在容器里面执行命令 |
scale | 指定一个服务容器启动数量(弹性伸缩时增加服务器结合consul一起部署) |
top | 显示正在运行的容器进程 |
logs | 查看服务容器的输出(生产环境中不建议直接查看所有日志) |
down | 删除容器、网络、数据卷和镜像 |
stop/start/restart | 停止/启动/重启服务 |
二、部署compose
1.安装compose
环境部署所有主机安装docker环境(内容为docker基础)
yum install docker-ce -y
2.下载compose
curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
cp -p docker-compose /usr/local/bin/
chmod +x /usr/local/bin/docker-compose
mkdir /root/compose_tomcat/tomcat
3.编写dockerfile文件
需要上传安装tomcat所需要的包
cd /root/compose_tomcat/tomcat
vim Dockerfile
FROM centos:7
ADD apache-tomcat-8.5.16.tar.gz /usr/local
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 JRE_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
RUN mv apache-tomcat-8.5.16 /usr/local/tomcat
EXPOSE 8080
ENTRYPOINT ["/usr/local/tomcat/bin/catalina.sh","run"]
4.编写dockers-compose.yml文件
cd /root/compose_tomcat
vim docker-compose.yml
version: '3'
services:
tomcat:
hostname: tomcat
build:
context: ./tomcat
dockerfile: Dockerfile
ports:
- 1216:8080
networks:
- cluster
volumes: #选配
- 宿主机目录:容器目录
networks:
cluster:
5.执行yml文件创建容器
docker-compose -f docker-compose.yml up -d