docker-compose理论和部署
docker-compose是什么
Docker Compose 与 Docker Stack 非常类似。它能够在 Docker 节点上,以单引擎模式(Single-Engine Mode)进行多容器应用的部署和管理。
多数的现代应用通过多个更小的服务互相协同来组成一个完整可用的应用。比如一个简单的示例应用可能由如下 4 个服务组成。
Web前端。
订单管理。
品类管理。
后台数据库。
将以上服务组织在一起,就是一个可用的应用。
部署和管理繁多的服务是困难的。而这正是 Docker Compose 要解决的问题。
Docker Compose 并不是通过脚本和各种冗长的 docker 命令来将应用组件组织起来,而是通过一个声明式的配置文件描述整个应用,从而使用一条命令完成部署。
应用部署成功后,还可以通过一系列简单的命令实现对其完整声明周期的管理。甚至,配置文件还可以置于版本控制系统中进行存储和管理。
Docker Compose 的背景
Docker Compose 的前身是 Fig。Fig 是一个由 Orchard 公司开发的强有力的工具,在当时是进行多容器管理的最佳方案。
Fig 是一个基于 Docker 的 Python 工具,允许用户基于一个 YAML 文件定义多容器应用,从而可以使用 fig 命令行工具进行应用的部署。
Fig 还可以对应用的全生命周期进行管理。
内部实现上,Fig 会解析 YAML 文件,并通过 Docker API 进行应用的部署和管理。
在 2014 年,Docker 公司收购了 Orchard 公司,并将 Fig 更名为 Docker Compose。
命令行工具也从 fig 更名为 docker-compose,并自此成为绑定在 Docker 引擎之上的外部工具。
虽然它从未完全集成到 Docker 引擎中,但是仍然受到广泛关注并得到普遍使用。
直至今日,Docker Compose 仍然是一个需要在 Docker 主机上进行安装的外部 Python 工具。
使用它时,首先编写定义多容器(多服务)应用的 YAML 文件,然后将其交由 docker-compose 命令处理,Docker Compose 就会基于 Docker 引擎 API 完成应用的部署。
docker-compose 部署
安装在docker-ce的基础上
yum -y inshall docker-ce
把docker-compose的包上传
[root@server1 ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
[root@server1 ~]# ls
anaconda-ks.cfg initial-setup-ks.cfg original-ks.cfg 模板 图片 下载 桌面
docker-compose nginx 公共 视频 文档 音乐
[root@server1 ~]# cp -p docker-compose /usr/bin/
[root@server1 ~]# cd /usr/bin/
[root@server1 bin]# ls
[root@server1 bin]# chmod +x docker-compose #给docker-compose脚本执行权限
[root@server1 ~]# mkdir docker_nginx #创建docker_nginx目录
[root@server1 ~]# yum -y install tree #下载一个目录树
用dockerfile写nginx
[root@server1 ~]# cd docker_nginx
[root@server1 docker_nginx]# mkdir nginx
[root@server1 docker_nginx]# cd nginx/
[root@server1 nginx]# ls
nginx-1.12.0.tar.gz
[root@server1 nginx]# vim dockerfile
FROM centos:7
MAINTAINER this is nginx
RUN yum -y update
RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx
ADD nginx-1.12.0.tar.gz /usr/local/src
WORKDIR /usr/local/src
WORKDIR nginx-1.12.0
RUN ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make && make install
ENV PATH /usr/local/nginx/sbin:$PATH
EXPOSE 80
EXPOSE 443
RUN echo "daemon off;">>/usr/local/nginx/conf/nginx.conf
ADD run.sh /run.sh
RUN chmod 755 /run.sh
CMD ["/run.sh"]
[root@server1 nginx]# vim run.sh
[root@server1 nginx]# cat run.sh
#!/bin/bash
/usr/local/nginx/sbin/nginx
[root@server1 nginx]# mkdir wr
[root@server1 nginx]# cd wr/
[root@server1 wr]# vim index.html
[root@server1 wr]# cat index.html
song
[root@server1 compose_nginx]# tree
.
├── nginx
│ ├── Dockerfile 创建容器脚本
│ ├── nginx-1.12.0.tar.gz 复制源码包
│ └── run.sh 启动服务脚本
└── wr
└── index.html 站点
创建yaml文件
yaml十一种标记语言很直观的数据序列化格式
文件格式及编写注意事项
不支持制表符tab键缩进,需要使用空格缩进
通常开头缩进2个空格
字符后缩进一个空格,如冒号、逗号、横杆
用#号注释
如果包括特殊字符用单引号引起来
布尔值必须用引号括起来
Docker Compose配置常用字段
字段 描述
build dockerfile context 指定Dockerfile文件名构建镜像上下文路径
image 指定镜像
command 执行命令,覆盖默认命令
container name 指定容器名称,由于容器名称是唯一-的, 如果指定自定义名称,则无法scale(建立副本)
deploy 指定部署和运行服务相关配置,只能在Swarm模式使用
environment 添加环境变量
networks 加入网络 (名称空间)
ports 暴露容器端口,与-p相同,但端口不能低于60
volumes 挂载宿主机路径或命令卷(数据卷)
restart 重启策略,默认no(失败,不会继续操作),always(失败,一直尝试重启,直到运行成功), no-failure,unless-stoped
hostname 容器主机名
Docker Compose常用命令
字段 描述
build 重新构建服务
ps 列出容器
up 创建和启动容器
exec 在容器里面执行命令
scale 指定一个服务容器启动数量
top 显示容器进程
logs 查看容器输出
down 删除容器、网络、数据卷和镜像
stop/start/restart 停止/启动/重启服务
基本的使用格式
docker-compose [options] [COMMAND] [ARGS...]
docker-compose选项
--verbose 输出更多调试信息
--version打印版本并退出
-f,--file FILE 使用特定的compose模板文件,默认为docker-compose.yml
-p,--project-name NAME指定项目名称,默认使用目录名称
创建模板脚本
[root@server1 docker_nginx]# vim docker-compose.yaml
[root@server1 docker_nginx]# docker-compose -f docker-compose.yaml up -d
[root@server1 docker_nginx]# cat docker-compose.yaml
version: '3'
services:
nginx:
hostname: nginx
build:
context: ./nginx
dockerfile: dockerfile
ports:
- 1234:80
- 1235:443
networks:
- cluster
volumes:
- ./wr:/usr/local/nginx/html
networks:
cluster: