思考
前面我们使用 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: