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. [转帖]PostgreSQL 10.0 preview 功能增强 - 国际化功能增强,支持ICU(International Components for Unicode)

    https://developer.aliyun.com/article/72935 标签 PostgreSQL , 10.0 , International Components for Unico ...

  2. [转帖]mvcc多版本并发控制的原理

      https://baijiahao.baidu.com/s?id=1751185558149315946 MVCC多版本并发控制的原理:通过undo_log多版本链条,加上开启事务时产生的read ...

  3. [转帖]redis进程绑定指定的CPU核

    文章系转载,便于分类和归纳,源文地址:https://blog.csdn.net/youlinhuanyan/article/details/99671878 1)查看某服务的pid $ ps -au ...

  4. [转帖]学习linux必须知道的命令

    https://www.cnblogs.com/aibeier/p/15315487.html 基础不牢,地动山摇.在linux命令行下查看命令帮助man用于查看命令的帮助信息 man cp--hel ...

  5. [读书笔记]SQLSERVER企业级平台管理实践读书笔记--从等待事件判断性能瓶颈

    用到的系统试图主要有: select * from sys.dm_os_wait_statsselect * from sys.sysprocessesselect * from sys.dm_exe ...

  6. Jekyll安装

    本文来自Jekyll官方文档. 简介 Jekyll是一个静态网站生成器,它可以把Markdown写就的文本根据指定的布局生成静态网站.你可以调整网站的外观.URL.页面展示数据等信息. 准备工作 Je ...

  7. IDM全版本激活工具

    前往IDM官网下载IDM IDM官网 下载破解工具 IDM激活工具.zip 解压打开激活工具选择1 然后回车耐心等待激活完成即可

  8. 通过Unity导出的Android Studio和Google安卓原生工程的结构图对比

    使用Unity导出Android Studio工程前建议查看我之前的文章<Unity2019及Unity2020打包android的环境配置>,替换或修改Unity安装目录下的basePr ...

  9. PaddleHub--飞桨预训练模型应用工具{风格迁移模型、词法分析情感分析、Fine-tune API微调}【一】

    相关文章: 基础知识介绍: [一]ERNIE:飞桨开源开发套件,入门学习,看看行业顶尖持续学习语义理解框架,如何取得世界多个实战的SOTA效果?_汀.的博客-CSDN博客_ernie模型 百度飞桨:E ...

  10. 8.5 Windows驱动开发:内核注册表增删改查

    注册表是Windows中的一个重要的数据库,用于存储系统和应用程序的设置信息,注册表是一个巨大的树形结构,无论在应用层还是内核层操作注册表都有独立的API函数可以使用,而在内核中读写注册表则需要使用内 ...