前面已经讲解过docker的一些基础使用,镜像创建的操作过程,如果大量容器需要同时部署,一个一个容器进行服务器上的部署,估计要疯掉,在使用上我们需要找到更好更便捷的使用方式,今天要讲解的容器编排工具docker-compose就是其中之一

简介

Compose是一个用于定义和运行多容器Docker应用程序的工具。使用Compose,您可以使用YAML文件来配置应用程序的服务。然后,使用单个命令,您可以从配置中创建并启动所有服务。

docker-compose作为容器编排工具,专门用于处理多容器部署问题,当然,目前对于系统运维有更好的处理方式,比如k8s,由于笔者并不是系统运维人员,所以不会涉及这么深入,本文也只是浅显的介绍下docker-compose,记录下自己的使用过程

特征

单个主机上的多个隔离环境

compose使用项目名称将环境彼此隔离。每次我们使用docker-compose创建多个容器时,其会自动帮我们将彼此环境进行隔离,非常有用

  • 在开发主机上,创建单个环境的多个副本,例如当您要为项目的每个功能分支运行稳定副本时
  • 在CI服务器上,为了防止构建相互干扰,可以将项目名称设置为唯一的构建号
  • 在共享主机或开发主机上,以防止可能使用相同服务名称的不同项目相互干扰

这里可以使用-p参数来设置此次compose启动的项目名,可以自行安装测试下

仅重新创建已更改的容器

compose会缓存用于创建容器的配置。当重新启动未更改的服务时,compose将重新使用现有容器。重用容器意味着您可以非常快速地更改环境。比如当我们使用compose启动一组容器时,如果我们更新了其中一个容器所使用的镜像,当我们执行更新容器命令时,docker-compose不会更新所有容器,只会更新那个改变了镜像的容器

共享文件和项目配置

compose支持在compose文件中定义变量。您可以使用这些变量为不同环境或不同用户自定义组合,参考官方文档:

https://docs.docker.com/compose/extends/

使用步骤

  • 定义您的应用程序环境,Dockerfile以便可以在任何地方进行复制
  • 定义构成应用程序的服务,docker-compose.yml 以便它们可以在隔离的环境中一起运行
  • Run docker-compose up和Compose启动并运行整个应用程序

安装

首先需要安装docker环境,然后再安装docker-compose,笔者是在centos7环境下安装的

1.安装依赖环境

  1. sudo yum install epel-release
  2. sudo yum install -y python-pip

2.安装docker-compose

  1. sudo pip install docker-compose

使用示例

以我自己的网站为例,目前个人网站部署在阿里云服务器上,以使用docker-compose进行部署,目前环境如下:

  • nginx前置机
  • solo博客服务
  • 数据库mysql

关于博客系统的部分,本人已部署过ghost,wordpress,太复杂感觉不适合我,目前选择了轻量级博客solo,后期有更适合的可能会进行替换

虽然只有一台云服务器,本人还是部署了集群服务,虽然没什么用,只是想多实践下,nginx单节点,solo双节点,mysql单节点,目前个人博客环境就是这样

配置文件

创建docker-compose.yml文件,vim操作修改如下,其中有些地方解释下:

在配置文件中,将需要保存的文件映射到宿主机上,即你自己的服务器真实目录或文件上,方便下次进行迁移或者容器出现无法恢复的问题时重新部署,其中需要注意的是,如果没有进行网络相关配置,且没有将端口与主机进行映射,则其会自行创建网络,使得这组容器可以相互访问,但是外界不能访问,宿主机也不行。这里将nginx容器进行了端口映射,这组容器只能通过这两个端口进行访问

nginx的配置文件中,如果配置了upstream,这里对应的server写solo_1:8080即可,对应配置文件,你可以把这里理解成这组容器中这个域名对应solo_1容器服务,至于nginx的配置文件部分,就不贴出来了,没有太多复杂的部分,自行找资料进行配置

  1. version: '2'
  2. services:
  3. solo_db:
  4. image: mysql:latest
  5. container_name: solo_db
  6. volumes:
  7. - /var/solomysql/data:/var/lib/mysql # 将数据库文件映射到本地服务器便于迁移
  8. restart: always
  9. expose:
  10. - 3306
  11. environment:
  12. MYSQL_ROOT_PASSWORD: 1234
  13. MYSQL_USER: root
  14. MYSQL_PASSWORD: so
  15. MYSQL_DATABASE: so
  16. solo_1:
  17. depends_on:
  18. - solo_db
  19. image: b3log/solo:v3.6.3
  20. container_name: solo_1
  21. volumes: # 日志配置文件和皮肤映射便于我配置修改,添加皮肤
  22. - /root/solodata/log4j.properties:/opt/solo/WEB-INF/classes/log4j.properties
  23. - /root/solodata/skins/:/opt/solo/skins/
  24. links:
  25. - solo_db
  26. expose:
  27. - 8080
  28. restart: always
  29. environment:
  30. RUNTIME_DB: MYSQL
  31. JDBC_USERNAME: so
  32. JDBC_PASSWORD: so
  33. JDBC_DRIVER: com.mysql.jdbc.Driver
  34. JDBC_URL: jdbc:mysql://solo_db:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
  35. command: --listen_port=8080 --server_port=80 --server_scheme=https --server_host=www.gclearning.cn
  36. solo_2:
  37. depends_on:
  38. - solo_db
  39. image: b3log/solo:v3.6.3
  40. container_name: solo_2
  41. volumes:
  42. - /root/solodata/log4j.properties:/opt/solo/WEB-INF/classes/log4j.properties
  43. - /root/solodata/skins/:/opt/solo/skins/
  44. links:
  45. - solo_db
  46. expose:
  47. - 8080
  48. restart: always
  49. environment:
  50. RUNTIME_DB: MYSQL
  51. JDBC_USERNAME: so
  52. JDBC_PASSWORD: so
  53. JDBC_DRIVER: com.mysql.jdbc.Driver
  54. JDBC_URL: jdbc:mysql://solo_db:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
  55. command: --listen_port=8080 --server_port=80 --server_scheme=https --server_host=www.gclearning.cn
  56. solonginx:
  57. image: docker.io/nginx:1.0 # 我自己将官方nginx镜像时区修改了下重新打包的镜像,用官方镜像也可,日志部分时间相差8个时区
  58. container_name: solonginx
  59. links:
  60. - solo_1
  61. - solo_2
  62. ports:
  63. - 80:80
  64. - 443:443
  65. volumes: # nginx配置文件,静态资源,证书等目录映射到宿主机上,可根据需要自行配置
  66. - /root/solonginx/nginxconfig/nginx.conf:/etc/nginx/nginx.conf
  67. - /root/solonginx/nginxconfig/conf.d:/etc/nginx/conf.d
  68. - /root/solonginx/log/:/var/log/nginx/
  69. - /root/solonginx/nginxconfig/cert/:/etc/nginx/cert/
  70. - /root/solonginx/nginxconfig/www/:/var/www/

运行容器组

在你所创建的docker-compose目录下,执行如下命令,即可启动一组容器

  1. docker-compose up -d

docker-compose ps 查看容器状态,处于up状态,则表示容器创建成功,如下:

如果我们修改了nginx配置,只需要对其中的nginx容器进行重启即可,执行如下命令:

  1. docker-compose restart solonginx

总结

docker-compose为我们同时操作一组容器提供了便捷的方式,多个服务之间需要进行编排,端口,网络,硬件配置等在我们定义好了之后可以方便我们进行部署,迁移,如果之后出现了无法恢复的问题,我们可以将落地的数据进行迁移,瞬间启动一组环境来对外提供服务,极大的解放了运维人员的生产力,也不用再为安装一堆依赖环境而头疼,也不用再记录各个服务之间的关系,配置等而忧虑

在学习与使用docker的过程中,越来越感觉到这种技术对运维的重要性(虽然我不是运维),开发人员当然也需要去了解其使用,会让你看到一个更开阔的技术领域

以上内容如有问题欢迎指出,笔者验证后将及时修正,谢谢

Docker那些事儿之编排工具docker-compose的更多相关文章

  1. Docker系列10—容器编排工具Docker Compose详解

    本文收录在容器技术学习系列文章总目录 1.Docker Compose 概述 Compose是一个用于定义和运行多容器Docker应用程序的工具.使用Compose,您可以使用Compose文件来配置 ...

  2. 使用容器编排工具docker swarm安装clickhouse多机集群

    1.首先需要安装docker最新版,docker 目前自带swarm容器编排工具 2.选中一台机器作为master,执行命令sudo docker  swarm init [options] 3,再需 ...

  3. Docker编排工具Docker Compose的使用

    一.安装docker compose 官网推荐方式之一: sudo curl -L "https://github.com/docker/compose/releases/download/ ...

  4. 单机编排之Docker Compose

    当在宿主机启动较多的容器时候,如果都是手动操作会觉得比较麻烦而且容器出错,这个时候推荐使用docker 单机编排工具docker compose,Docker Compose 是docker容器的一种 ...

  5. Docker系列08—搭建使用私有docker registry

    本文收录在容器技术学习系列文章总目录 1.了解Docker Registry 1.1 介绍 registry 用于保存docker 镜像,包括镜像的层次结构和元数据. 启动容器时,docker dae ...

  6. Docker Compose编排工具部署lnmp实践及理论(详细)

    目录 一.理论概述 编排 部署 Compose原理 二.使用docker compose 部署lnmp 三.测试 四.总结 一.理论概述 Docker Compose是一个定义及运行多个Docker容 ...

  7. 走进docker-swarm 带大家快速掌握docker自带编排工具

    什么是Docker Swarm? 对比Docker 前面我们介绍过Docker可以理解成是一个我们的服务的独立运行的容器,那么在实际工作中,我们的系统可能是一个微服务应用,系统中根据业务拆分成多个模块 ...

  8. Docker入门(三)使用Docker Compose

    Compose介绍   Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排.Compose 是一个用户定义和运行多个容器的 Docker 应用程序.在 ...

  9. docker--docker compose 编排工具

    11 docker compose 编排工具 11.1 docker compose 介绍 根据前面所学的知识可知,想要使用Docker部署应用,就要先在应用中编写Dockerfile 文件来构建镜像 ...

随机推荐

  1. [转帖]鲁大师Q3季度PC处理器排行:AMD、Intel终于五五开了

    鲁大师Q3季度PC处理器排行:AMD.Intel终于五五开了 https://www.cnbeta.com/articles/tech/902375.htm 近日,鲁大师发布了Q3季度PC处理器排行. ...

  2. [Asp.Net Core] - 设置 Syncfusion / RichTextEditor 移除超链接及高度自适应 的方法

    背景 使用 Syncfusion / RichTextEditor 对录入后的信息进行展示:1. 希望内容高度自适应.2. 希望禁用原文中的超链接.   实现 <div class=" ...

  3. Spring Boot开启Druid数据库监控功能

    Druid是一个关系型数据库连接池,它是阿里巴巴的一个开源项目.Druid支持所有JDBC兼容的数据库,包括Oracle.MySQL.Derby.PostgreSQL.SQL Server.H2等.D ...

  4. todo----mysql常用语句总结补充完成

    todo----mysql常用语句总结补充完成

  5. centos7 为使用su命令的用户添加pam授权认证

    # 查看用户所属哪个组 groups 用户名 #查看当前有哪些用户运行程序 ps -aux|awk '{print $1}'|sort -rn|uniq -c|sort -rn # 清理不再使用的用户 ...

  6. 定期备份和清理gitlab文件

    #!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2019-12-05 14:39 # @Author : Anthony # @Emai ...

  7. PAT(B) 1074 宇宙无敌加法器(Java)

    题目链接:1074 宇宙无敌加法器 (20 point(s)) 题目描述 地球人习惯使用十进制数,并且默认一个数字的每一位都是十进制的.而在 PAT 星人开挂的世界里,每个数字的每一位都是不同进制的, ...

  8. java之aop使用及自定义注解

    目的: 1.Java注解简介 2.Java元注解(重点) 3.自定义注解 案例一(获取类与方法上的注解值) 案例二(获取类属性上的注解属性值) 案例三(获取参数修饰注解对应的属性值) 4.Aop自定义 ...

  9. PAT-1111 Online Map (30分) 最短路+dfs

    明天就要考PAT,为了应付期末已经好久没有刷题了啊啊啊啊,今天开了一道最短路,状态不是很好 1.没有读清题目要求,或者说没有读完题目,明天一定要注意 2.vis初始化的时候从1初始化到n,应该从0开始 ...

  10. manacher 算法(最长回文串)

    manacher算法: 定义数组p[i]表示以i为中心的(包含i这个字符)回文串半径长 将字符串s从前扫到后for(int i=0;i<strlen(s);++i)来计算p[i],则最大的p[i ...