Docker-Compose部署及编排

前言: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	   //停止/启动/重启服务
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值