手记

『中级篇』Docker Compose到底是什么(38)

多容器的APP太恶心了

美团,阿里,京东一个项目很多个容器,如果扩展那不是运维人员基本没办法干了,几千个几万个。

  • 要从Dockerfile build image 或者去dockerhub拉取image

  • 要创建多个container

  • 要管理这些container(启动停止删除)

DOcker Compose "批处理"

通过文本的方式,把要处理的容器按照顺序执行,如果是多容器也就是通过一条命令就搞定了

Docker Compose 了解它

https://docs.docker.com/compose/overview/ ,version版本统一用3,其实3是兼容2的,version版本1 就不要考虑了已经废弃了,一定要往前看。3和2的最大区别是3比2强大,好像是废话,3支持多机和单机,2仅支持单机。

  • Docker Compose 是一个工具,命令行工具。

  • 这个工具可以通过yml文件定义多容器的docker应用

  • 通过一条命令就可以根据yml文件的定义去创建或者管理这多个容器

docker-compose.yml 介绍
  • services

    1. 一个service代表一个container,这个container可以从dockerhub的image来创建,或者从本地的Dockerfile build出来的image来创建。

    2. service的启动类似docker run,我们可以给其指定network和volme,所以可以给service指定network和volume的引用

  • networks


  • volumes


docker-compose 上例子

源码地址:https://github.com/limingios/docker中的No.4

  • 访问路径


  • docker-compose 源码实例

#docker-Compse的版本version: '3'#建立2个service 一个wordpress 一个 mysqlservices:

  wordpress:
    image: wordpress#端口映射80 映射到8080端口
    ports:
      - 8080:80#环境变量2个
    environment:
      WORDPRESS_DB_HOST: mysql
      WORDPRESS_DB_PASSWORD: root
    networks:
      - my-bridge

  mysql:
    image: mysql
    environment:
      MYSQL_ROOT_PASSWORD: root
      MYSQL_DATABASE: wordpress
    volumes:
      - mysql-data:/var/lib/mysql
    networks:
      - my-bridge#建立一个volumes volumes:
  mysql-data:#建立一个networksnetworks:
  my-bridge:
    driver: bridge

PS:上节通过image 和container的方式创建wordpress,一般麻烦吧还不算特别麻烦,但是相比今天的docker-compose.yml来说,还是docker-compose.yml文件更方便些吧。



作者:IT人故事会
链接:https://www.jianshu.com/p/0623dd1f7ec6

0人推荐
随时随地看视频
慕课网APP