1、docker-compose的简介

docker-compose作为dokcer的官方编排工具,它可以让用户通过编写一个简单的模板文件,快速地创建和管理基于docker容器的应用集群。实现对docker容器集群的快速编排。我们知道Dockerfile模板文件,可以让用户很方便地定义一个单独的应用容器。然而在日常工作中,经常会遇到需要多个容器相互配合来完成某项任务的情况。例如要实现一个web项目,除了web服务器容器本身,往往还需要加上后端的数据库服务容器,甚至还包括负载均衡容器等。 
    而Compose正好可以满足这样的需求,它允许用户通过一个单独的docker-compose.yml模板文件(YAML格式)来定义一组相关联的应用容器作为一个项目(project) 
    Compose中有2个重要的概念: 
    (1)服务(service):一个应用的容器,实际上可以包含若干运行相同镜像的容器实例。 
    (2)项目(project):由一组关联的应用容器组成的一个完成业务单元,在docker-compose.yml文件中定义。

2、docker-compose安装

Compose项目是用Python语言编写的,所以compose可以通过pythonpip工具进行安装。安装过程如下:

[root@localhost ~]# yum install -y python-pip
[root@localhost ~]# pip install -U docker-compose
[root@localhost ~]# docker-compose version
docker-compose version 1.21., build 5920eb0
docker-py version: 3.2.
CPython version: 2.7.
OpenSSL version: OpenSSL 1.0.1e-fips Feb

3、Compose命令

对于Compose来说,大部分命令的对象既可以是项目本身,也可以指定为项目中的服务或容器。如果没有特别说明,命令对象将是项目,这意味着项目中所有的服务都会受到命令的影响。docker-compose命令的基本使用格式如下:

Usage:
docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...]
docker-compose -h|--help Options:
-f, --file FILE 指定使用的Compose模板文件,默认为docker-compose.yml,可多次指定;
-p, --project-name NAME 指定项目名称,默认将使用所在目录名称作为项目名 ;
--verbose 输出更多调试信息; -v, --version 打印版本信息; Commands:
build 构建项目中的服务容器
help 获得一个命令的帮助
images 列出所有镜像
kill 通过发送SIGKILL信号来强制停止服务容器
logs 查看服务器容器的输出
pause 暂停一个服务容器
port 打印某个容器的端口所映射的公共端口
ps 列出项目中目前的所有容器
pull 拉取服务依赖的镜像
push 推送服务依赖的镜像
restart 重启项目中的服务
rm 删除所有的服务器容器(停止状态中的)
run 在指定服务上执行一个命令
scale 设置指定服务运行的容器个数
start 启动已经存在的服务容器
stop 停止已经处于运行状态的容器,但不删除它
top 展示运行的进程
unpause 恢复处于暂停状态中的服务
up 自动完成包括构建镜像、创建服务、启动服务并关联服务相关容器的一系列操作
version 打印docker-compose的版本信息

4、Compose模板文件

模板文件是使用Compose的核心,设计的指令关键字也有很多,默认的模板文件名称为docker-compose.yml,格式为YAML格式。举例:

version: ""
service:
webapp:
image: examplses/web
ports:
- "80:80"
volumes:
- "/data"

注意,每个服务都必须通过image指定镜像或build命令(需要Dockerfile)等来自动构建生成镜像。如果使用build指令,在Dockerfile中设置的选项(例如:CMD、EXPOSE、VOLUME、ENV等)将会自动被获取,无需在docker-compose.yml中再次设置。以下为模板的主要指令和功能:

(1)build指令

指定Dockerfile所在文件夹的路径(可以是绝对路劲,或相对docker-compose.yml文件的路径。)Compose将会利用它自动构建这个镜像,然后使用这个镜像:

build: /path/to/build/dir

(2)cap_add,cap_drop

指定容器的内核能力(capacity)分配。例如,让容器拥有所有能力可以指定为:

cap_add:
- ALL

去掉NET_ADMIN能力可以指定为:

cap_drop:
- NET_ADMIN

(3)command

覆盖容器启动后默认执行的命令:

command: echo "hello world"

(4)cgroup_parent

指定父cgroup组,意味着将继承该组的资源限制,例如,创建了一个cgroup组为cgroups_1

cgroup_parent: cgroups_1

(5)container_name

指定容器名称。默认将会使用“项目名称_服务名称_序号”这样的格式。例如:

container_name: docker-web-container
指定容器名称后,该服务将无法进行扩展,因为Docker不允许多个容器具有相同的名称。

(6)devices

指定设备映射关系,例如:

devices:
- "/dev/ttyUSB1:/dev/ttyUSB0"

(7)dns

自定义DNS服务器。可以是一个值,也可以是一个列表,例如:

dns: 8.8.8.8
dns:
- 8.8.8.8
- 114.114.114.114

(8)dns_search

配置DNS搜索域。可以是一个值,也可以是一个列表,例如:

dns_search: example.com
dns_search:
- domain1.example.com
- domain2.example.com

(9)dockerfile

如果需要,指定额外的编译镜像的Dockerfile文件,可以通过该指令来指定,例如: 
该指令不能和image一起使用,否则Compose不知道根据哪个指令来生成最终的服务镜像。

dockerfile: Dockerfile-alternate

(10)env_file

从文件中获取环境变量,可以为单独的文件路径或列表。 
如果通过docker-compose -f FILE的方式来指定Compose模板文件,则env_file中变量的路径会基于模板文件路径,如果有变量名称和environment指令冲突,则按照惯例,以后者为准:

env_file: .env
env_file:
- ./common.env
- ./apps/web.env
- ./opt/secrets.env
环境变量文件中每一行都必须符合格式,支持#开头的注释行:

(11)environment

设置环境变量,可以使用数组或字典两种格式。只给定名称的变量会自动获取运行Compose主机上对应变量的值,可以用来防止泄露不必要的数据。例如:

environment:
RACK_ENV: development
SESSION_SECRET
或者:
environment:
- RACK_ENV=development
- SESSION_SECRET

(12)expose

暴露端口,但不映射到宿主机,只允许能被链接的服务访问。仅可以指定内部端口为参数,如下所示:

expose:
- ""
- ""

(13)extends

基于其他模板文件进行扩展。例如我们已经有了一个webapp服务,定义一个基础模板文件为common.yml,如下所示:

# common.yml
webapp:
build: ./webapp
environment:
- DEBUG=false
- SEND_EMAILS=false

再编写一个新的development.yml文件,使用common.yml中的webapp服务进行扩展:

#development.yml
web:
extends:
file: common.yml
service: webapp
ports:
- "8000:8000"
links:
- db
environment:
- DEBUG=true
db:
image: postgres
development.yml会自动继承common.yml中的webapp服务及环境变量定义。使用extends需要注意以下几点:
1.避免出现循环依赖,如A依赖B,B依赖C,C依赖A
2.extends不会继承links和volume_from中定义的容器和数据卷资源。
一般情况下,推荐在基础模板中只定义一些可以共享的镜像和环境变量,在扩展模板中具体指定应用变量、链接、数据卷等信息。

(14)external_links

链接到docker-compose.yml外部的容器,甚至可以是非Compose管理的外部容器。参数格式和links类似

external_links:
- redis_1
- project_db_1:mysql
- project_db_1:postgresql

(15)extra_hosts

类似于Docker中的–add-host参数,指定额外的host名称映射信息,例如:

extra_hosts:
- "googledns:8.8.8.8"
- "dockerhub:52.1.157.61" 会在启动后的服务容器中/etc/hosts文件中添加以下2个条目:
8.8.8.8 googledns
52.1.157.61 dockerhub

(16)image

指定为镜像名称或镜像ID,如果镜像在本地不存在,Compose将会尝试拉取这个镜像。

image: centos
image: nginx

(17)labels

为容器添加Docker元数据(metadata)信息。例如,可以为容器添加辅助说明信息:

labels:
com.startupteam.description: "webapp for a startup team"
com.startupteam.department: "devops department"
com,startupteam.release: "rc3 for v1.0"

(18)links

链接到其他服务中的容器。使用服务名称(同时作为别名),或者”服务名称:服务别名”(如SERVICE:ALIAS),这样的格式都可以,例如:

links:
- db
- db:database
- redis
使用的别名会将自动在服务容器中的/etc/hosts里创建。例如:
172.17.2.186 db
172.17.2.186 database
172.17.2.187 redis
所连接容器中相应的环境变量也将创建

(19)log_driver

类似于Docker中的–log-driver参数,指定日志驱动类型。目前支持三种日志驱动类型:

log_driver: "json-file"
log_driver: "syslog"
log_driver: "none"

(20)log_opt

日志驱动的相关参数。例如:

log_driver: "syslog"
log_opt:
syslog-address: "tcp://192.168.0.42:123"

(21)net

设置网络模式。参数类似于docker client的–net参数

net: "bridge"
net: "none"
net: "container:[name or id]"
net: "host"

(22)pid

跟主机系统共享进程命名空间。打开该选项的容器之间,以及容器和宿主机系统之间可以通过进程ID来相互访问和操作:

pid: "host"

(23)ports

暴露端口信息。使用”宿主:容器“的格式,或者仅仅指定容器的端口(宿主机会随机选择端口):

ports:
- ""
- "8000:8000"
- "49100:22"
- "127.0.0.1:8081:8081" 当使用"HOST:CONTAINER"格式来映射端口时,如果你使用的容器端口小于60并且没有放到引号里,可能会得到错误结果,因为YAML会自动解析xx:yy这种数字格式为60进制。为了避免这种问题的出现,建议数字串都用引号包括起来的字符串格式。

(24)security_opt

指定容器模板标签(label)机制的默认属性(用户、角色、类型、级别等)。例如,配置标签的用户名和角色名:

security_opt:
- label:user:USER
- label:role:ROLE

(25)ulimits

指定容器的ulimits限制值,例如,指定最大进程数为65535,指定文件句柄数位20000(软限制,应用可以随时修改,不能超过硬限制,只能root用户提高)。

ulimits:
nproc:
nofile:
soft:
hard:

(26)volumes

数据卷所挂载的路径设置。可以设置宿主机路径(HOST:CONTAINER)或加上访问模式(HOST:CONTAINER:ro)。该指令中路径支持相对路径。例如:

volumes:
- /var/lib/mysql
- cache/:/tmp/cache
- ~/configs:/etc/configs/:ro

(27)volumes_driver

较新版本的Docker支持数据卷的插件驱动。用户可以先使用第三方驱动创建一个数据卷,然后使用名称来访问它。此时,可以通过volumes_driver来指定驱动:

volume_driver: mydriver

(28)volumes_from

从另一个服务或容器挂载它的数据卷:

volumes_from:
- service_name
- container_name

Docker入门篇(三)之docker-compose单机编排的更多相关文章

  1. 【Docker】(1)---Docker入门篇

    Docker入门篇 简单一句话: Docker 是一个便携的应用容器. 一.Docker的作用 网上铺天盖地的是这么说的: (1) Docker 容器的启动可以在秒级实现,这相比传统的虚拟机方式要快得 ...

  2. Docker 入门 第三部分: 服务

    目录 Docker 入门 第三部分: 服务 先决条件 介绍 你的第一个 docker-compose.yml 文件 docker-compose.yml 运行你新建的负载均衡应用 扩展应用程序 卸载应 ...

  3. Docker入门篇(一)安装docker

    Docker入门篇(一)安装docker Docker的来源 由dotCloud公司首创及正式命名,但是企业规模小,影响力不够,所以在快要坚持不住的时候,开始吃百家饭--开源了.不开则已,一开惊人.越 ...

  4. Docker入门(三):容器(Containers)

    这个<Docker入门系列>文档,是根据Docker官网(https://docs.docker.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指 ...

  5. Docker入门 .Net Core 使用Docker全程记录

    https://www.cnblogs.com/flame7/p/9210986.html Docker入门 第一课 --.Net Core 使用Docker全程记录   微服务架构无疑是当前最火热的 ...

  6. Docker入门之 - 如何安装Docker CE

    原文:Docker入门之 - 如何安装Docker CE 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u012055638/article/det ...

  7. 【SSRS】入门篇(三) -- 为报表定义数据集

    原文:[SSRS]入门篇(三) -- 为报表定义数据集 通过前两篇文件 [SSRS]入门篇(一) -- 创建SSRS项目 和 [SSRS]入门篇(二) -- 建立数据源 后, 我们建立了一个SSRS项 ...

  8. 【实战】Docker入门实践二:Docker服务基本操作 和 测试Hello World

    操作环境 操作系统:CentOS7.2 内存:1GB CPU:2核 Docker服务常用命令 docker服务操作命令如下 service docker start #启动服务 service doc ...

  9. Docker入门(三)使用Docker Compose

    Compose介绍   Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排.Compose 是一个用户定义和运行多个容器的 Docker 应用程序.在 ...

  10. Docker 入门篇

    Docker 简介 作为一种新兴的虚拟化方式,Docker 跟传统的虚拟化方式相比具有众多的优势. 更高效的利用系统资源 更快速的启动时间 一致的运行环境 持续交付和部署 更轻松的迁移 更轻松的维护和 ...

随机推荐

  1. python BaseManager中register()的描述

    register(typeid[, callable[, proxytype[, exposed[, method_to_typeid[, create_method]]]]]) A classmet ...

  2. 简析Chrome和Webkit的渊源

    http://www.3lian.com/edu/2012/05-25/28803.html 互联网的浪潮从未停息,而用以网上冲浪的冲浪板也一直在变得愈加精良.自人们进入互联网时代以来,即已经发生了三 ...

  3. Guava包学习---Sets

    Sets包的内容和上一篇中的Lists没有什么大的区别,里面有些细节可以看一下: 开始的创建newHashSet()的各个重载方法.newConcurrentHashSet()的重载方法.newTre ...

  4. AI-Info-Micron:用内存解决方案演化神经网络智能

    ylbtech-AI-Info-Micron:用内存解决方案演化神经网络智能 1.返回顶部 1. 用内存解决方案演化神经网络智能 我们的大脑每天会进行数千次极其复杂的操作.无论是提醒我们小心被炉子烫到 ...

  5. 【MySQL-123】MySQL8.0.12 安装于Win10

    参考blog:MySQL8.0.12 安装及配置 [坑一]输入net start mysql时,MYSQL服务无法启动. 问题:第三步my.ini文件编码错误. 解决方案:https://blog.c ...

  6. 关于JavaScript 常见的面试题

    关于JavaScript常见的面试题总结 一.JavaScript基本数据类型 null:空.无.表示不存在,当为对象的属性赋值为null,表示删除该属性 undefined:未定义.当声明变量却没有 ...

  7. 纸质文稿如何生成PDF

    步骤: (1) 将即将要转换的文稿单张向下放入打印机. (2) 将打印设备(打印机)连接至你的电脑. (3) 打开控制面板,点击"查看设备和打印机". (4) 找到你当前的打印设备 ...

  8. orcal 数据库 maven架构 ssh框架 的全xml环境模版 及常见异常解决

    创建maven项目后,毫不犹豫,超简单傻瓜式搞定dependencies(pom.xml 就是maven的依赖管理),这样你就有了所有你要的包 <project xmlns="http ...

  9. MySQL常用:Got a packet bigger than 'max_allowed_packet' bytes & MySQL开远程服务

    1. 数据导入时出现错误 Got a packet bigger than 'max_allowed_packet' bytes 通过终端进入mysql控制台 mysql>show VARIAB ...

  10. MySQL案例03:(MyCAT报错) [ERROR][$_NIOREACTOR-3-RW] caught err: java.lang.OutOfM emoryError: Unable to acquire 131072 bytes of memory, got 0

    上班坐下来没多久,接同事电话说有两台mysql服务器无法访问,其中这两台服务器是mycat服务器+MySQL服务器,具体处理过程如下: 一.错误信息 错误信息01: :: ::, [INFO ][$_ ...