前面已经讲解过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.安装依赖环境

sudo yum install epel-release
sudo yum install -y python-pip

2.安装docker-compose

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的配置文件部分,就不贴出来了,没有太多复杂的部分,自行找资料进行配置

version: '2'
services:
solo_db:
image: mysql:latest
container_name: solo_db
volumes:
- /var/solomysql/data:/var/lib/mysql # 将数据库文件映射到本地服务器便于迁移
restart: always
expose:
- 3306
environment:
MYSQL_ROOT_PASSWORD: 1234
MYSQL_USER: root
MYSQL_PASSWORD: so
MYSQL_DATABASE: so solo_1:
depends_on:
- solo_db
image: b3log/solo:v3.6.3
container_name: solo_1
volumes: # 日志配置文件和皮肤映射便于我配置修改,添加皮肤
- /root/solodata/log4j.properties:/opt/solo/WEB-INF/classes/log4j.properties
- /root/solodata/skins/:/opt/solo/skins/
links:
- solo_db
expose:
- 8080
restart: always
environment:
RUNTIME_DB: MYSQL
JDBC_USERNAME: so
JDBC_PASSWORD: so
JDBC_DRIVER: com.mysql.jdbc.Driver
JDBC_URL: jdbc:mysql://solo_db:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
command: --listen_port=8080 --server_port=80 --server_scheme=https --server_host=www.gclearning.cn solo_2:
depends_on:
- solo_db
image: b3log/solo:v3.6.3
container_name: solo_2
volumes:
- /root/solodata/log4j.properties:/opt/solo/WEB-INF/classes/log4j.properties
- /root/solodata/skins/:/opt/solo/skins/
links:
- solo_db
expose:
- 8080
restart: always
environment:
RUNTIME_DB: MYSQL
JDBC_USERNAME: so
JDBC_PASSWORD: so
JDBC_DRIVER: com.mysql.jdbc.Driver
JDBC_URL: jdbc:mysql://solo_db:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
command: --listen_port=8080 --server_port=80 --server_scheme=https --server_host=www.gclearning.cn solonginx:
image: docker.io/nginx:1.0 # 我自己将官方nginx镜像时区修改了下重新打包的镜像,用官方镜像也可,日志部分时间相差8个时区
container_name: solonginx
links:
- solo_1
- solo_2
ports:
- 80:80
- 443:443
volumes: # nginx配置文件,静态资源,证书等目录映射到宿主机上,可根据需要自行配置
- /root/solonginx/nginxconfig/nginx.conf:/etc/nginx/nginx.conf
- /root/solonginx/nginxconfig/conf.d:/etc/nginx/conf.d
- /root/solonginx/log/:/var/log/nginx/
- /root/solonginx/nginxconfig/cert/:/etc/nginx/cert/
- /root/solonginx/nginxconfig/www/:/var/www/

运行容器组

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

docker-compose up -d

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

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

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. SPSS 2019年10月24日 今日学习总结

    2019年10月24日今日课上内容1.SPSS掌握基于键值的一对多合并2.掌握重构数据3.掌握汇总功能 内容: 1.基于键值的一对多合并 合并文件 添加变量 合并方法:基于键值的一对多合并 变量 2. ...

  2. vue el-table 自适应表格内容宽度

    由于表头和列是分开渲染的,通过el-table 设置fit属性,只能撑开表头,但是没有办法根据列的内容去适应宽度.网上找了一些使用根据表格内容计算表头宽度的文章,记个笔记. 代码逻辑是通过vue  的 ...

  3. solr关于日期范围查询

    问题:从solr上查询创建日期在2019-06-25到2019-06-26之间的数据 createDate:[2019-06-25 TO 2019-06-26]

  4. lnmp二级域名配置相关

    阿里云那域名解析那有误读 我在偏远的电信网选择中国联通解析死活解析不出来 以上这么配置就对了....选择默认.瞬间解析出来.... 出于对nginx 配置不够熟悉 后来一点点理出来. 不带www 也正 ...

  5. 从零开始学Flask框架-005

    表单 Flask-WTF 项目结构 pip install flask-wtf 为了实现CSRF 保护,Flask-WTF 需要程序设置一个密钥.Flask-WTF 使用这个密钥生成加密令牌,再用令牌 ...

  6. Python re模块学习

    这是re模块与正则的结合 re模块提供的函数 1.match  尝试在字符串的开头应用该模式,返回匹配对象,如果没有找到匹配,则为None. import re str1 = "Why ar ...

  7. STM32中引脚复用说明

    端口复用的定义 STM32有许多的内置外设(如串口.ADC.DCA等等),这些外设的外部引脚都是和GPIO复用的.也就是说,一个GPIO如果可以复用为内置外设的功能引脚,那么当这个GPIO作为内置外设 ...

  8. (转)基于FFPMEG2.0版本的ffplay代码分析

    ref:http://zzhhui.blog.sohu.com/304810230.html 背景说明 FFmpeg是一个开源,免费,跨平台的视频和音频流方案,它提供了一套完整的录制.转换以及流化音视 ...

  9. Angular 学习笔记 (Angular 9 & ivy)

    refer : https://blog.angularindepth.com/all-you-need-to-know-about-ivy-the-new-angular-engine-9cde47 ...

  10. java第一次笔试+面试总结

    今天是自己第一次java笔试和面试,总体感觉比预期好一点. 笔试题第一面是问答题,主要考查java基础,一共有18题,我有6道题没有写出来.第二面主要是算法题,一共有8道题,我大概写出来4道题,第三面 ...