专栏首页eadeladocker--docker compose 编排工具

docker--docker compose 编排工具

11 docker compose 编排工具

11.1 docker compose 介绍

根据前面所学的知识可知,想要使用Docker部署应用,就要先在应用中编写Dockerfile 文件来构建镜像。同样,在微服务项目中,我们也需要为每一个服务编写Dockerfile文件 来构建镜像。构建完成后,就可以根据每一个镜像使用docker run或者docker service create命令创建并启动容器,这样我们就可以访问容器中的服务了。 微服务架构中:涉及的服务数量巨多。 虽然使用上述方式可以部署微服务项目,但考虑到微服务项目可能有多个子服务组成, 并且每个服务启动过程中都需要配置额外的参数(如-e配置环境变量、--network指定网 络、磁盘挂载等等)。这种情况下,每次更新微服务后,都要手动运行指令来重新启动 容器,这就显得相当麻烦了。针对这种多服务部署的情况,Docker提供了Docker Compose编排工具来对多服务应用进行统一部署。Compose是Docker的服务编排工 具,主要用来构建基于Docker的复杂应用,Compose 通过一个配置文件来管理多个 Docker容器,非常适合组合使用多个容器进行开发的场景。 通过该编排工具,可以使用yml(或yaml)文件来配置应用程序服务,然后只需要一条简 单的服务部署指令就可以从配置中创建并启动所有服务。

11.2 docker compose 安装与卸载

安装docker compose

1、环境要求:Docker Compose是依赖于Docker引擎的,所以在安装Docker Compose之前
要确保机器上已经安装了Docker。https://github.com/docker/compose/releases
(查看docker compose版本)
2、下载docker‐compose工具
curl ‐L
https://github.com/docker/compose/releases/download/1.24.0/docker‐
compose‐`uname ‐s`‐`uname ‐m` ‐o /usr/local/bin/docker‐compose
3、设置docker compose可执行文件权限
chmod +x /usr/local/bin/docker‐compose
r:read  w:write x:ex
4、查看docker compose版本
docker‐compose ‐‐version
PS:卸载docker compose
sudo rm /usr/local/bin/docker‐compose

11.3 docker compose 使用

11.3.1 例子

 步骤:分为三步(在创建的一个空目录下执行)
1、编写Dockerfile文件(为每个服务构建需要的镜像,方便迁移‐不是必须的)
2、编写docker‐compose.yml文件(编写部署服务相关指令)
3、运行docker‐compose up(启动yml文件中服务)
案例:
1、准备:两个镜像(本次演示就不通过Dockerfile构建了)
docker pull mysql:5.7
docker pull wordpress
2、需要新建一个空白目录,例如rwtest。新建一个docker‐compose.yml,编辑该文件:
version: '3'
services:
   db:
     image: mysql:5.7
     volumes:
       ‐ db_data:/var/lib/mysql
     restart: always
     environment:
       MYSQL_ROOT_PASSWORD: wordpress
       MYSQL_DATABASE: wordpress
       MYSQL_USER: wordpress
       MYSQL_PASSWORD: wordpress
   wordpress:
     depends_on:
       ‐ db
     image: wordpress:latest
     ports:
       ‐ "8001:80"
     restart: always
     environment:
       WORDPRESS_DB_HOST: db:3306
       WORDPRESS_DB_USER: wordpress
       WORDPRESS_DB_PASSWORD: wordpress
volumes:
    db_data:
       
该文件中内容:新建db和wordpress容器。等同于:
docker run ‐‐name db ‐e MYSQL_ROOT_PASSWORD=123456 ‐d mysql
docker run ‐‐name some‐wordpress ‐‐link db:mysql ‐p 8002:80 ‐d wordpress
3、启动docker compose
docker‐compose up
4、浏览器访问:http://ip:8001
5、停止/重启服务:docker‐compose stop/restart

注意:键值对冒号后要有空格

11.3.2 docker compose 指令说明

 1 version: '3'  
 2 services:  
 3   web:  
 4     image: id/imagename:lable  
 5     restart: on‐failure  
 6     container_name: my‐web‐container  
 7     ports:  
 8       ‐ 8080:8080  
 9    networks:    
 10       ‐ example‐net 
 11     depends_on: 
 12       ‐ db 
 13     deploy: 
 14       replicas: 2 
 15       restart_policy: 
 16         condition: on‐failure 
 17   db: 
 18     image: mysql:5.6 
 19     restart: on‐failure 
 20     container_name: my‐mysql‐container    
 21     ports: 
 22       ‐ 3306:3306 
 23     volumes: 
 24       ‐ example‐mysql:/var/lib/mysql 
 25     networks: 
 26       ‐ example‐net 
 27     environment: 
 28       MYSQL_ROOT_PASSWORD: root 
 29       MYSQL_DATABASE: mysql_database 
 30     deploy: 
 31       replicas: 1 
 32       restart_policy: 
 33         condition: on‐failure 
 34       placement: 
 35         constraints: [node.role == manager] 
 36 networks: 
 37   example‐net: 
 38 volumes: 
 39   example‐mysql: 
  • version :version通常在一个docker-compose.yml文件的最顶部,用来表示文件内 容的约束版本(类似于XML文件约束)(版本越高,支持的指令越多)
  • services 用来声明服务,在services下的所有同缩进的应用名称都代表一个服务,如 上面示例中的web和db。在进行多服务部署的时候,有多少个服务需要同时部署, 就需要在services参数下面声明并配置多少个服务
    • image :容器启动需要依赖的镜像(如果本地没有会自动pull)
    • restart :服务重启策略
      • restart: "no" # 服务默认值为no,即服务失败后没有任何动作
      • restart: always # 表示服务会一直重新启动
      • restart: on-failure # 表示服务提示失败错误后会重新启动
      • restart: unless-stopped # 表示只有服务在停止后才会重启
    • container_name :指定容器名称
    • ports :指定服务向外暴露的端口
    • networks :指定容器使用的网络
    • depends_on :服务依赖决定了服务的依赖关系,如示例中的web依赖db,所以 db服务会先于web服务启动,但并不表示db服务完全启动成功后才启动web服 务,它只决定启动的先后顺序而已
    • deploy :deploy参数是Docker Compose针对Swarm集群部署提供的,子参数 专门用于指定与服务部署和运行相关的配置
      • replicas :表示服务实例的副本数量
      • restart_policy :estart_policy参数同前面介绍的restart类似,都是用来配置 服务重启策略的,只是该属性配置在deploy参数下,并只在集群环境下生 效。该参数包含多个子属性及属性值
        • condition: on-failure # 表示服务重启的条件,值有none、on-failure和 any
        • delay: 5s # 表示重启服务之间等待时间,默认为0
        • max_attempts: 3 # 表示失败后尝试重启的次数
        • window: 120s # 表示等待多久来确定服务是否启动成功
      • placement :placement用来配置指定位置的约束,当服务在Swarm集群环 境下部署时会随机分配到管理节点和其他工作节点上。在上述示例中由于将 mysql数据挂载到了本机example-mysql数据卷中,所以使用了placement 的子参数constraints: [node.role == manager]指定该服务只在manager管 理节点上运行 :
    • environment 用于配置服务启动时需要的环境变量。如上述示例中 MYSQL_ROOT_PASSWORD表示数据库root用户的密码,MYSQL_DATABASE表 示数据库启动后自动创建的数据库。
  • networks :用于配置服务网络
  • volumes :目录挂载,上述示例中是将mysql数据挂载到本地example-mysql数据卷 中,如果该数据卷不存在,服务启动时也会默认创建

其他配置可参考:https://docs.docker.com/compose/compose-file/

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • docker--docker 的web可视化管理工具

    当 Docker 部署规模逐步变大后,可视化监控容器环境的性能和健康状态将会变得越来越 重要。 Docker的图形化管理工具,提供状态显示面板、应用模板快速部署...

    eadela
  • docker--镜像制作

    docker官方和个人发布的镜像由于版本等各种原因,漏洞较多,已统计Docker Hub超过 30%的官方镜像包含高危漏洞。此外,由于网络等原因也会造成dock...

    eadela
  • docker--docker版本以及安装

    Docker CE 在 17.03 版本之前叫 Docker Engine, Docker Engine 的版本号范围: 0.1.0 ~ 1.13.1 在 20...

    eadela
  • Docker compose 安装 PostgreSQL 和 MySQL

    记录一下 Docker compose 安装 PostgreSQL 和 MySQL。

    木制robot
  • Docker 介绍、核心概念、常用命令

    Docker支持将软件编译成一个镜像;然后在镜像中各种软件做好配置,将镜像发布出去,其他使用者可以直接使用这个镜像。运行中的这个镜像称为容器,容器启动后非常快速...

    桑鱼
  • 虚拟机Docker安装MySQL5.7并配置宿主机访问

    Windows下VMware的Linux的Docker安装MySQL5.7,并配置Windows下可连接该MySQL。

    无道
  • MySQL的单表多表查询

    #4.like 'fdfdsf': parttern可以是%或_。 %表示任意多字符,_表示一个字符

    老油条IT记
  • 这就是你日日夜夜想要的docker!!!---------Dockerfile构建nginx、Tomcat、MySQL镜像

    2、CMD是开启容器时,要执行的指令,设置容器启动后默认执行的命令及其参数,但 CMD 能够被 docker run 后面跟的命令行参数替换

    不吃小白菜
  • canda 常用命令

    第三步:其他人拿到environment.yml文件后,将该文件放到工作目录下,可以通过以下命令用该文件创建环境

    py3study
  • Kubernetes(9:数据)

    emptyDir是Host上创建的临时目录,其优点是能够方便地为Pod中的容器提供共享存储,不需要额外的配置。它不具备持久性,如果Pod不存在了,emptyDi...

    用户5760343

扫码关注云+社区

领取腾讯云代金券