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

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值