1. Compose简介

Docker Compose是Docker官方的用于对Docker容器集群实现编排,快速部署分布式应用的开源项目。Docker Compose通过docker-compose.yml文件来定义一组相关联的应用容器的编排,这组相关联的应用容器一般通过互相交互作为一个整体项目提供服务,比如一个Web项目,既包含业务服务容器,也包含数据库服务容器与缓存服务容器等。

Compose中两个重要的概念:

  • 服务(service): 包含多个运行相同镜像的容器实例

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

Copmpose项目由Python编写,通过调用Docker服务提供的API来对容器进行管理。Compose默认的管理对象是项目,可以通过子命令对项目中的一组容器进行生命周期管理。

2. Compose安装

在macOS与Win10下,Docker安装自带了docker-compose的二进制文件,可以直接使用。
Linux下,

[root@iZwz ~]# curl -L "https://github.com/docker/compose/releases/download/1.24.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

[root@iZwz ~]# chmod +x /usr/local/bin/docker-compose

验证

[root@iZwz ~]# docker-compose version
docker-compose version 1.24., build 4667896b
docker-py version: 3.7.
CPython version: 3.6.
OpenSSL version: OpenSSL 1.1.0j Nov

3. Compose模板文件

模板文件是使用Compose的核心,定义了一组相关联的应用容器,使之构成一个项目,里面大部分指令跟docker run相关参数的含义是类似的。默认的模板文件名称为docker-compose.yml,为YAML格式,如

version: '3'
services:
web:
build: .
depends_on:
- db
- redis redis:
image: redis db:
image: mysql

Compose模板文件可以动态读取主机的系统环境变量与当前目录下.env文件中的变量,通过${xx}引用。

模板文件中的常用指令说明

  • build
    指定Dockerfile所在文件夹的路径,可以是绝对路径或相对模板文件的路径。Compose将会自动构建镜像,然后使用该镜像。也可以通过如下方式详细指定。cache_from指定构建镜像的缓存

    build:
    context: ./dir
    dockerfile: Dockerfile-alternate
    args:
    buildno: 1
    cache_from:
    - alpine:latest
    - corp/web_app:3.14
  • command
    覆盖容器启动后默认执行的命令。

  • container_name
    Compose默认会使用 项目名称服务名称序号的格式作为容器名称。一般不需要特别指定,因为指定具体名称后,服务将无法进行扩展(scale),因为不允许多个容器具有相同的名称。

  • depends_on
    解决容器的依赖、启动先后顺序的问题,但是服务不会等待依赖的服务“完全启动”之后才启动。

  • env_file
    指定环境变量定义文件,可以为单独文件路径或列表,当与environment中有同名冲突时,以environment为准。

  • environment
    设置环境变量,支持数组或字典两种格式。只有名称的变量会自动获取运行Compose主机上的对应变量的值,以防止信息泄露

    environment:
    RACK_ENV: development
    SESSION_SECRET: environment:
    - RACK_ENV=development
    - SESSION_SECRET
  • expose
    暴露端口,不映射到宿主机,只被连接的服务访问

  • healthcheck
    通过命令检查容器是否健康运行,如

    healthcheck:
    test: ["CMD", "curl", "-f", "http://localhost"]
    interval: 1m30s
    timeout: 10s
    retries: 3
  • image
    指定镜像名称或镜像ID,所有服务都必要要么通过build,要么通过image来指定镜像。

  • labels
    为容器添加Docker元数据信息

  • network_mode
    设置网络模式,与docker run的–network一样,如bridge,host,none等,也可以是如下形式

    network_mode: "service:[service name]"
    network_mode: "container:[container name/id]"
  • networks
    配置容器连接的网络,如

    services:
    service1:
    networks:
    - some-network
    - other-network
    networks:
    some-network:
    other-network:
  • ports
    暴露端口信息,遵循端口映射规则。

  • secrets
    存储敏感数据,如密码等信息

    mysql:
    image: mysql
    environment:
    MYSQL_ROOT_PASSWORD_FILE: /run/secrets/db_root_password
    secrets:
    - db_root_password
    - my_other_secret secrets:
    my_secret:
    file: ./my_secret.txt
    my_other_secret:
    external: true
  • volumes
    容器的数据卷挂在路径设置,可以设置多个,与docker -v类似,如

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

4. Compose命令

Compose命令默认是针对项目本身,也可以指定为项目中的服务或容器。
docker-compose 命令的基本使用格式为

docker-compose [-f=<arg>...] [options] [COMMAND] [ARGS...]

命令选项

  • -f, –file 指定模板文件,默认为docker-compose.yml,可多次指定

  • -p, –project-name 指定项目名称,默认为所在目录名称

  • –x-networking 使用Docker的可插拔网络特性

  • –x-networking-driver 指定网络驱动,默认为bridge

  • –verbose 输出更多调试信息

  • -v, –version 打印版本信息

命令使用说明

  • build 格式为docker-compose build [options] [SERVICE...],构建项目中的服务容器,选项包括 –force-rm(删除构建过程中的临时容器),–no-cache(构建镜像过程不使用cache),–pull(始终尝试通过pull来获取最新版本镜像)

  • config 验证模板文件格式是否正确

  • down 停止up命令启动的容器,并移除网络

  • exec 进入指定的容器

  • images 列出compose文件中包含的镜像

  • kill 格式为docker-compose kill [options] [SERVICE...],强制停止服务容器

  • logs 格式为docker-compose logs [options] [SERVICE...],查看服务容器的输出

  • pause 格式为docker-compose pause [SERVICE...], 暂停一个服务容器

  • port 格式为docker-compose port [options] SERVICE PRIVATE_PORT,打印容器端口所映射的公共端口,–index=index(指定容器序号,默认为1)

  • ps 格式为docker-compose ps [options] [SERVICE...],列出项目中目前的所有容器

  • pull 格式为docker-compose pull [options] [SERVICE...],拉去服务依赖的镜像

  • push 推送服务依赖的镜像到Docker镜像仓库

  • restart 重启项目中服务,格式为docker-compose restart [options] [SERVICE...]

  • rm 删除所有停止的服务容器,格式docker-compose rm [options] [SERVICE...], -f(强制直接删除)

  • run 在指定服务上执行一个命令,不会自动创建端口,以避免冲突

  • scale 格式docker-compose scale [options] [SERVICE=NUM...],设置指定服务运行的容器个数,少则新建,多则删除

  • start 格式docker-compose start [SERVICE...],启动已经存在的服务容器

  • stop 停止运行中的容器

  • top 查看各个服务容器内运行的进程

  • unpause 格式docker-compose unpause [SERVICE...],恢复处于暂停状态的服务

  • up 格式docker-compose up [options] [SERVICE...],尝试自动完成包括构建镜像,创建服务,启动服务,关联服务相关容器的一系列操作,大部分时候都可以通过该命令来启动一个项目,-d(在后台启动所有容器)。docker-compose up --no-recreate只启动处于停止状态的容器,忽略已经运行的服务,docker-compose up --no-deps -d <SERVICE_NAME>重新创建服务,但不影响到它所依赖的服务

5. 总结

Compose是Docker官方的服务容器编排工具,对一些简单的但包含多个组件的服务可以借助Compose来快速搭建环境,如开源的错误监控系统sentry,包括sentry服务本身,redis,postgres。对于业务生产环境,则一般使用功能更为丰富的第三方编排系统如Kubernetes来部署。


欢迎关注我的微信公众号:jboost-ksxy

Docker笔记(十二):Docker Compose入门的更多相关文章

  1. 《C++游戏开发》笔记十二 战争迷雾:初步实现

    本系列文章由七十一雾央编写,转载请注明出处.  http://blog.csdn.net/u011371356/article/details/9475979 作者:七十一雾央 新浪微博:http:/ ...

  2. python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL

    python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL实战例子:使用pyspider匹配输出带.html结尾的URL:@config(a ...

  3. Go语言学习笔记十二: 范围(Range)

    Go语言学习笔记十二: 范围(Range) rang这个关键字主要用来遍历数组,切片,通道或Map.在数组和切片中返回索引值,在Map中返回key. 这个特别像python的方式.不过写法上比较怪异使 ...

  4. DirectX11笔记(十二)--Direct3D渲染8--EFFECTS

    原文:DirectX11笔记(十二)--Direct3D渲染8--EFFECTS 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010333737 ...

  5. Docker笔记--ubuntu安装docker

    Docker笔记--ubuntu安装docker 1.更换国内软件源,推荐中国科技大学的源,稳定速度快(可选) sudo cp /etc/apt/sources.list /etc/apt/sourc ...

  6. Docker笔记(二):Docker管理的对象

    原文地址:http://blog.jboost.cn/2019/07/14/docker-2.html 在Docker笔记(一):什么是Docker中,我们提到了Docker管理的对象包含镜像.容器. ...

  7. Docker(二十二)-Docker Swarm常用命令

    #查看集群节点 docker node ls #创建nginx服务 #docker pull hub.test.com:5000/almi/nginx:0.1 #下载私有仓库镜像 docker ser ...

  8. java jvm学习笔记十二(访问控制器的栈校验机制)

    欢迎装载请说明出处:http://blog.csdn.net/yfqnihao 本节源码:http://download.csdn.net/detail/yfqnihao/4863854 这一节,我们 ...

  9. Docker进阶之二:Docker内部组件

    Docker内部组件 一.Namespaces 命名空间,Linux内核提供的一种对进程资源隔离的机制,例如进程,网络,挂载点等资源.    docker run -d busybox ping ba ...

  10. Docker笔记一:Docker介绍

    目录 什么是Docker? Docker的核心概念 Docker镜像命令 Docker容器命令 Docker实战 查看我的镜像 启动Redis Docker中国镜像加速 血与泪的教训 什么是Docke ...

随机推荐

  1. 小白学 Python(6):基础运算符(下)

    人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...

  2. 如何定制 Spring Boot 的 Banner?

    相信用过 Spring Boot 的朋友们一定在启动日志中见过类似如下的内容,比如在启动 Spring Boot 时,控制台默认会打印 Spring Boot Logo 以及版本信息,这是 Sprin ...

  3. 斯坦福机器学习课程 Exercise 习题四

    Exercise 4: Logistic Regression and Newton’s Method 回顾一下线性回归 hθ(x)=θTx Logistic Regression hθ(x)=11+ ...

  4. (一)django创建

    1.打开终端,安装django:输入pip install django 2.创建django项目:django-admin startproject myweb 3.启动项目:进入到myweb,输入 ...

  5. web.xml 配置文件 超详细说明!!!

    一.web.xml是什么? 首先 web.xml 是java web 项目的一个重要的配置文件,但是web.xml文件并不是Java web工程必须的. web.xml文件是用来配置:欢迎页.serv ...

  6. 在线预览office文件

    Office Online 实现在线预览 office的在线预览,针对不同的浏览器版本和系统具有要求,具体的相关文档请参考官方文档. 利用office online 平台进行office 文档的在线查 ...

  7. python:__name__的使用

    1.python中__name__是什么意思? 很多python的初学者可能都会遇到一个问题:__name__是什么意思? 在刚开始学习python的时候,我们总会看到这样一句代码: if __nam ...

  8. 20190723_C的三个小实现

    1. 有一个字符串开头或结尾含有n个空格(“    abcdefgdddd   ”),欲去掉前后的空格,返回一个新的字符串.a) 要求1:请自己定义一个接口(函数),并实现功能:b) 要求2:编写测试 ...

  9. [2018-01-13] 什么是Django

    什么是Django? Django是一个基于Python的高级Web开发框架 它能够让开发人员进行高效且快速的开发 高度集成(不用自己造轮子),免费并且开源(内部已经实现了许多高级的功能) 浏览器浏览 ...

  10. Linux基于webRTC的二次开发(一)

    最近在做Linux平台下webRTC的二次开发,一路摸索,中间踩了不少坑,这一篇博客先来简单介绍下Linux上如何使用GCC编译webRTC. 为什么使用GCC编译? 这其实是无奈之举,Linux下w ...