Docker Compose是什么

https://github.com/docker/compose

可以按项目为单位管理多个Docker容器,Python语言开发,底层调用Docker的API接口。

Docker Compose解决的是单个主机上快速启停多个容器,以及管理容器之间依赖关系的问题。

如何安装

# 安装1.2.0版本的docker compose,一定要注意docker compose版本,如果版本不对,在运行时可能会报错:"Unsupported config option"
$ sudo curl -L https://github.com/docker/compose/releases/download/1.2.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
$ sudo chmod a+x /usr/local/bin/docker-compose

命令行

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

	-f,--file        :指定yaml配置文件,默认:docker-compose.yml
-p,--project-name:指定项目名,默认:执行docker-compose命令所在的目录名(注:如果启动服务时指定了-p参数,那么停止服务时也必须指定-p参数)
--log-level LEVEL :指定日志级别,可选值:DEBUG, INFO, WARNING, ERROR, CRITICAL
--verbose :输出更多调试信息 Commands:
build Build or rebuild services
config Validate and view the Compose file
create Create services
down Stop and remove resources
events Receive real time events from containers
exec Execute a command in a running container
help Get help on a command
images List images
kill Kill containers
logs View output from containers
pause Pause services
port Print the public port for a port binding
ps List containers
pull Pull service images
push Push service images
restart Restart services
rm Remove stopped containers
run Run a one-off command
scale Set number of containers for a service
start Start services
stop Stop services
top Display the running processes
unpause Unpause services
up Create and start containers
version Show version information and quit

yaml文件指令

Docker Compose编排容器是通过配置yaml文件配置的,默认的文件名称是docker-compose.yml,其中定义的每个服务都必须通过image指令指定镜像或 build 指令(需要 Dockerfile)来自动构建。

可以在配置文件中使用的指令如下阐述。

1.image

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

image: ubuntu
image: orchardup/postgresql
image: a4bc65fd

2.build

指定Dockerfile所在文件夹的路径,Compose将会利用它自动构建这个镜像,然后使用这个镜像。

build: /path/to/build/dir

3.command

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

command: bundle exec thin -p 3000

4.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

相应的环境变量也将被创建。

5.external_links

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

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

6.ports

暴露端口信息。

使用“宿主:容器”(HOST:CONTAINER)格式或者仅仅指定容器的端口(宿主将会随机选择端口)都可以。

ports:
- "3000"
- "8000:8000"
- "49100:22"
- "127.0.0.1:8001:8001"

注意:当使用HOST:CONTAINER格式来映射端口时,如果你使用的容器端口小于60可能会得到错误得结果,因为YAML将会解析xx:yy这种数字格式为60进制,所以建议采用字符串格式。

7.expose

暴露端口,但不映射到宿主机,只被连接的服务访问。

仅可以指定容器内部端口为参数:

expose:
- "3000"
- "8000"

8.volumes

卷挂载路径设置。

可以设置宿主机路径(主机路径:容器路径)或加上访问模式(主机路径:容器路径:ro)。

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

9.volumes_from

从另一个服务或容器挂载它的所有卷。

volumes_from:
- service_name
- container_name

10.environment

设置环境变量,可以使用数组或字典两种格式。

只给定名称的变量会自动获取它在Compose主机上的值,可以用来防止泄露不必要的数据。

environment:
RACK_ENV: development
SESSION_SECRET: environment:
- RACK_ENV=development
- SESSION_SECRET

11.env_file

从文件中获取环境变量,可以为单独的文件路径或列表。

如果通过docker-compose -f FILE指定了模板文件,则env_file中路径会基于模板文件路径。

如果有变量名称与environment指令冲突,则以后者为准。

env_file: .env

env_file:
- ./common.env
- ./apps/web.env
- /opt/secrets.env

环境变量文件中每一行必须符合格式,支持#开头的注释行。

# common.env: Set Rails/Rack environment
RACK_ENV=development

12.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

后者会自动继承 common.yml 中的 webapp 服务及相关环节变量。

13.net

设置网络模式,使用和docker client--net参数一样的值。

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

14.pid

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

pid: "host"

15.dns

配置DNS服务器,可以是一个值,也可以是一个列表。

dns: 8.8.8.8
dns:
- 8.8.8.8
- 9.9.9.9

16.dns_search

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

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

17.cap_add, cap_drop

添加或放弃容器的 Linux 能力(Capabiliity)。

cap_add:
- ALL cap_drop:
- NET_ADMIN
- SYS_ADMIN

18.working_dir, entrypoint, user, hostname, domainname, mem_limit, privileged, restart, stdin_open, tty, cpu_shares

这些都是和docker run支持的选项类似。

cpu_shares: 73

working_dir: /code
entrypoint: /code/entrypoint.sh
user: postgresql hostname: foo
domainname: foo.com mem_limit: 1000000000
privileged: true restart: always stdin_open: true
tty: true

【参考】

https://www.runoob.com/docker/docker-compose.html Docker Compose

https://docs.docker.com/engine/reference/commandline/compose/ Docker Compose命令行

https://www.jianshu.com/p/658911a8cff3 Docker:Docker Compose 详解

http://www.dockerinfo.net/docker-compose-项目 Docker Compose 项目

https://juejin.cn/post/6870401513357836302 14个用于DevOps的容器编排工具

https://blog.51cto.com/devopsvip/3196552 10个最佳的Docker容器集群编排工具

https://www.infoq.cn/article/6itsptlczt6sbkdevokn 这可能是网上最全的 Docker 工具集合

Docker进阶之01-Docker Compose编排工具的更多相关文章

  1. docker--docker compose 编排工具

    11 docker compose 编排工具 11.1 docker compose 介绍 根据前面所学的知识可知,想要使用Docker部署应用,就要先在应用中编写Dockerfile 文件来构建镜像 ...

  2. Docker Compose编排工具部署lnmp实践及理论(详细)

    目录 一.理论概述 编排 部署 Compose原理 二.使用docker compose 部署lnmp 三.测试 四.总结 一.理论概述 Docker Compose是一个定义及运行多个Docker容 ...

  3. docker快速入门01——docker安装与简单应用

    1.docker简介 Docker 是一个开源的应用容器引擎,Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化 ...

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

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

  5. 使用容器编排工具docker swarm安装clickhouse多机集群

    1.首先需要安装docker最新版,docker 目前自带swarm容器编排工具 2.选中一台机器作为master,执行命令sudo docker  swarm init [options] 3,再需 ...

  6. 01: docker 基本使用

    1.1 docker基础 1.docker与虚拟机比较 2.docker版本 1. 社区版(Community Edition, CE) 2. 企业版(Enterprise Edition, EE) ...

  7. Docker进阶之三:Docker应用场景

    场景一:节省项目环境部署时间 1.单项目打包 每次部署项目到测试.生产等环境,都要部署一大堆依赖的软件.工具,而且部署期间出现问题几率很大,不经意就花费了很长时间. Docker主要理念就是环境打包部 ...

  8. Docker - 容器编排工具 compose 之安装

    准备 首先,在使用和安装 docker compose之前,我们应该确保我们已经安装了 docker engine. 安装 官网上面有好多种安装方式,由于我们现在是在使用Docker, 个人感觉应该以 ...

  9. docker之compose 编排项目

    一.docker-compose 的介绍 docker-compose是一种容器编排工具,可以将多个docker容器关联部署.通过yaml文件,可以描述应用的架构,如使用什么镜像.数据卷.网络.绑定服 ...

  10. 使用Docker compose编排Laravel应用

    前言 Laravel官方开发环境推荐的是Homestead(其实就是一个封装好的Vagrant box),我感觉这个比较重,于是自己用Docker compose编排了一套开发环境,在这里分享下. 环 ...

随机推荐

  1. [转帖]没 K8s 用不了 Chaos Mesh?试试 Chaosd

    https://cn.pingcap.com/blog/cannot-use-chaosmesh-without-k8s-then-try-chaosd Chaosd 是什么? 相信大家对 Chaos ...

  2. [转帖]Linux 监测服务心跳、服务重启策略

    文章目录 前言 背景 一.curl服务可用验证 二.服务探测脚本 三.配置系统定时任务 四.Linux特殊字符转义 总结 前言 请各大网友尊重本人原创知识分享,谨记本人博客:南国以南i. 提示:以下是 ...

  3. [转帖]Linux系统awk命令详解

    AWK 是一种处理文本文件的语言,是一个强大的文本分析工具. 之所以叫 AWK 是因为其取了三位创始人 Alfred Aho,Peter Weinberger, 和 Brian Kernighan 的 ...

  4. Oracle 设置白名单过滤

    最近有一个需求  要求开发人员不能随便连接测试的数据库 又不想太过复杂,部分人还得进行连结. 查了下往上是有方案的: 就是 TCP_VALIDNODE_CHECKING 参数 解决方法和说明如下 来源 ...

  5. Oracle12c 快速启动命令设置

    Oracle12c 安装完成之后 一般不会自动启动需要进行一下简单的设置才可以. 方法也比较简单. 可以使用 oracle 自带的 dbstart的命令执行服务启动 需要注意的事项是: 第一修改一个参 ...

  6. echarts定义饼状图的指向线内容

    定义饼状图的指向线内容 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...

  7. 【分享一个工具】根据 /metrics 路径下的文本信息,自动生成包含所有 metrics 的 grafana 报表

    作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢! cnblogs博客 zhihu Github 公众号:一本正经的瞎扯 在做某个服务对应的 grafana 监控报表的时候发现,一 ...

  8. Gorm 应用开发时区问题与unique唯一索引字段数据冲突问题

    目录 一.定义表模型时区问题 1.1 time.Time 与int64 1.2 优势 二.unique唯一索引字段数据冲突问题 一.定义表模型时区问题 1.1 time.Time 与int64 一般情 ...

  9. Paddlenlp之UIE分类模型【以情感倾向分析新闻分类为例】含智能标注方案)

    相关文章: Paddlenlp之UIE模型实战实体抽取任务[打车数据.快递单] 项目连接:百度AIstudio直接fork我的项目就可以复现 Paddlenlp之UIE分类模型[以情感倾向分析新闻分类 ...

  10. tensorflow语法【tf.gather_nd、reduce_sum、collections.deque 、numpy.random.seed()、tf.gradients()】

    相关文章: [一]tensorflow安装.常用python镜像源.tensorflow 深度学习强化学习教学 [二]tensorflow调试报错.tensorflow 深度学习强化学习教学 [三]t ...