zoukankan      html  css  js  c++  java
  • dcoker-componse-2

    思考

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

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

    什么是Docker Compose

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

    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 来进行编排管理。

    Docker Compose 安装与卸载

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

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

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

    Linux 系统安装

    二进制安装(官方推荐)

    从 官方 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

    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

    卸载

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

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

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

    sudo pip uninstall docker-compose

    Docker Compose 使用

    术语

    首先介绍几个术语。

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

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

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

    Docker-compose创建容器

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

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

    mkdir -p /usr/local/docker/tomcat

    创建一个docker-compose.yml文件

    version: '3'

    services:

    tomcat:

    restart: always

    image: tomcat

    container_name: tomcat_qfjy

    ports:

    - 8080:8080

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

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

    docker-compose up -d

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

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

    访问tomcat服务主页即可

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

    docker-compose 常用命令

    build 构建或重建服务

    help 命令帮助

    kill 杀掉容器

    logs 显示容器的输出内容

    port 打印绑定的开放端口

    ps 显示容器

    pull 拉取服务镜像

    restart 重启服务

    rm 删除停止的容器

    run 运行一个一次性命令

    scale 设置服务的容器数目

    start 开启服务

    stop 停止服务

    up 创建并启动容器

    down

    常用命令示例:

    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容器

    Docker Compose 部署

    tomcat

    创建项目目录

    mkdir –p /usr/local/docker/qfjy_exam

    该当目录下创建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

    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:

  • 相关阅读:
    【用例篇】Xmind转为csv 导入禅道
    idea替换当前文件内容
    配置IDEA项目JDK环境
    git 只提交部分修改文件
    `总结TESTNG与JUNIT的异同
    POST请求BODY格式区别
    【转】使用AllureReport生成测试报告
    Springboot+Redis 配置和使用
    【转】git branch 命令查看分支、删除远程分支、本地分支
    [转]Json字符串和map和HashMap之间的转换
  • 原文地址:https://www.cnblogs.com/qfchen/p/11430880.html
Copyright © 2011-2022 走看看