小小千想和您聊一聊

当前位置: 首页> 技术分享> dcoker-componse-2

dcoker-componse-2


  1. 思考

  前面我们使用 Docker 的时候,定义 Dockerfile 文件,然后使用 docker build、docker run 等命令操作容器。然而微服务架构的应用系统一般包含若干个微服务,每个微服务一般都会部署多个实例,如果每个微服务都要手动启停,那么效率之低,维护量之大可想而知

  使用 Docker Compose 可以轻松、高效的管理容器,它是一个用于定义和运行多容器 Docker 的应用程序工具

  2. 什么是Docker Compose

  Docker Compose 是 Docker 官方编排(Orchestration)项目之一,负责快速的部署分布式应用。

  3. Docker Compose 简介

  Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排。从功能上看,跟 OpenStack 中的 Heat 十分类似。

  其代码目前在 https://github.com/docker/compose 上开源。

  Compose 定位是 「定义和运行多个 Docker 容器的应用(Defining and running multi-container Docker applications)」,其前身是开源项目 Fig。

  通过第一部分中的介绍,我们知道使用一个 Dockerfile 模板文件,可以让用户很方便的定义一个单独的应用容器。然而,在日常工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个 Web 项目,除了 Web 服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。

  Compose 恰好满足了这样的需求。它允许用户通过一个单独的 docker-compose.yml 模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。

  Compose 中有两个重要的概念:

  · 服务 (service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。

  · 项目 (project):由一组关联的应用容器组成的一个完整业务单元,在 docker-compose.yml 文件中定义。

  Compose 的默认管理对象是项目,通过子命令对项目中的一组容器进行便捷地生命周期管理。

  Compose 项目由 Python 编写,实现上调用了 Docker 服务提供的 API 来对容器进行管理。因此,只要所操作的平台支持 Docker API,就可以在其上利用 Compose 来进行编排管理。

  4. Docker Compose 安装与卸载

  Compose 支持 Linux、macOS、Windows 10 三大平台。

  Compose 可以通过 Python 的包管理工具 pip 进行安装,也可以直接下载编译好的二进制文件使用,甚至能够直接在 Docker 容器中运行。

  Docker for Mac 、Docker for Windows 自带 docker-compose 二进制文件,安装 Docker 之后可以直接使用。

  Linux 系统安装

  4.1. 二进制安装(官方推荐)

  1、 从 官方 GitHub Release 处直接下载编译好的二进制文件

  Linux 64 位系统上直接下载对应的二进制包

curl -L https://github.com/docker/compose/releases/download/1.24.0-rc1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose

chmod +x /usr/local/bin/docker-compose

  卸载:rm /usr/local/bin/docker-compose

  可能产生问题:

  可以通过尝试域名解析方式:

  ping github-production-release-asset-2e65be.s3.amazonaws.com

  得到ip 52.216.101.115

  在linux的/etc/hosts上添加上以下一句,问题解决

  52.216.101.115 github-production-release-asset-2e65be.s3.amazonaws.com

  4.2. PIP 安装(推荐此安装)

  #查看docker compose版本

  docker-compose version

  #查看pip版本

  pip -v

  #上一条语句没有显示版本信息则运行下面语句安装 python-pip

  yum -y install epel-release

  yum -y install python-pip

  #查看pip版本

  pip -v

  #pip进行升级

  pip install --upgrade pip

  如果不成功,因为源问题,请尝试更改其它源进行下载(设置yum源)。

  yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

  #进行安装compose 第一条语句报错执行第二条,执行成功则跳过第二条

  pip install docker-compose

  pip install docker-compose --ignore-installed requests

  #查看版本

  docker-compose -version

  默认会安装到此目录: /usr/local/bin/docker-compose

  4.3. 卸载

  如果是二进制包方式安装的,删除二进制文件即可

  sudo rm /usr/local/bin/docker-compose

  如果是通过 pip 安装的,则执行如下命令即可删除。

  sudo pip uninstall docker-compose

  5. Docker Compose 使用

  5.1. 术语

  首先介绍几个术语。

  · 服务 (service):一个应用容器,实际上可以运行多个相同镜像的实例。

  · 项目 (project):由一组关联的应用容器组成的一个完整业务单元。

  可见,一个项目可以由多个服务(容器)关联而成,Compose 面向项目进行管理。

  5.2. Docker-compose创建容器

  通过一个单独的 docker-compose.yml 模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。

  1、 管理文件夹(创建相应目录)

  mkdir -p /usr/local/docker/tomcat

  2、 创建一个docker-compose.yml文件

version: '3'

services:

tomcat:

restart: always

image: tomcat

container_name: tomcat_qfjy

ports:

- 8080:8080

  编写 docker-compose.yml 文件,这个是 Compose 使用的主模板文件。

  3、 启动(执行命令 创建容器)

  docker-compose up -d

  默认执行的文件名:docker-compose.yml(且需要在当前上下文路径中) 。如果说文件名不是默认的需要使用下面的指令:

  docker-compose -f 文件名.后缀名 up –d

  4、 访问tomcat服务主页即可

  Docker-Compse可以用来定义或运行复杂的容器

  5.3. docker-compose 常用命令

  build 构建或重建服务

  help 命令帮助

  kill 杀掉容器

  logs 显示容器的输出内容

  port 打印绑定的开放端口

  ps 显示容器

  pull 拉取服务镜像

  restart 重启服务

  rm 删除停止的容器

  run 运行一个一次性命令

  scale 设置服务的容器数目

  start 开启服务

  stop 停止服务

  up 创建并启动容器

  down

  5.4. 常用命令示例:

  docker-compose up -d nginx 构建启动nignx容器

  docker-compose exec nginx bash 登录到nginx容器中

  docker-compose down 删除所有nginx容器,镜像

  docker-compose ps 显示所有容器

  docker-compose restart nginx 重新启动nginx容器

  docker-compose run --no-deps --rm php-fpm php -v 在php-fpm中不启动关联容器,并容器执行php -v 执行完成后删除容器

  docker-compose build nginx 构建镜像 。

  docker-compose build --no-cache nginx 不带缓存的构建。

  docker-compose logs nginx 查看nginx的日志

  docker-compose logs -f nginx 查看nginx的实时日志

  docker-compose config -q 验证(docker-compose.yml)文件配置,当配置正确时,不输出任何内容,当文件配置错误,输出错误信息。

  docker-compose events --json nginx 以json的形式输出nginx的docker日志

  docker-compose pause nginx 暂停nignx容器

  docker-compose unpause nginx 恢复ningx容器

  docker-compose rm nginx 删除容器(删除前必须关闭容器)

  docker-compose stop nginx 停止nignx容器

  docker-compose start nginx 启动nignx容器

  6. Docker Compose 部署

  6.1. tomcat

  1、 创建项目目录

  mkdir –p /usr/local/docker/qfjy_exam

  2、 该当目录下创建docker-compose.yml

  vim docker-compose.yml

  Mysql参考:https://www.cnblogs.com/mmry/p/8812599.html

  分别查看安装tomcat和mysql的数据卷信息。

version: '3'

services:

tomcat:

restart: always

image: tomcat

container_name: exam_tomcat

ports:

- 8080:8080

volumes:

- /usr/local/docker/qfjy_exam/ROOT:/usr/local/tomcat/webapps/ROOT

  6.2. mysql

  创建项目目录

  mkdir –p /usr/local/docker/mysql

  数据库

  /var/lib/docker/volumes

version: '3'

services:

mysql:

restart: always

image: mysql:5.6

container_name: mysql5.6

ports:

- 3306:3306

environment:

TZ: Asia/Shanghai

MYSQL_ROOT_PASSWORD: 密码

volumes:

- mysql-data:/var/lib/mysql

volumes:

mysql-data:


上一篇:HTML5工具初识之网页编辑器

下一篇:EXT2/3/4文件系统

QQ技术交流群

千锋Java开发官方①群
811099962

加入群聊