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. [转帖]GPT4All 一个开源 ChatGPT

    https://zhuanlan.zhihu.com/p/618947904 通用预训练语言模型. ChatGPT 正在迅速发展与传播,新的大型语言模型 (LLM) 正在以越来越快的速度开发.就在过去 ...

  2. [转帖] 传参base64时的+号变空格问题

    https://www.cnblogs.com/codelogs/p/17255425.html 原创:扣钉日记(微信公众号ID:codelogs),欢迎分享,非公众号转载保留此声明. 问题发生# 上 ...

  3. [转帖]webpagetest 私有化部署

    https://www.jianshu.com/p/83bd6b3473ae 介绍 webpagetest 是一款开源的 web 性能测试工具,开源地址,每个人都可在其公共实例上对自己的 web 应用 ...

  4. [转帖]iptables命令详解和举例(完整版)

    1.防火墙概述 防火墙,其实说白了讲,就是用于实现Linux下访问控制的功能的,它分为硬件的或者软件的防火墙两种.无论是在哪个网络中,防火墙工作的地方一定是在网络的边缘.而我们的任务就是需要去定义到底 ...

  5. [转帖]FT-2000+/64 - Phytium

      https://en.wikichip.org/wiki/phytium/feiteng/ft-2000%2B-64 Edit Values FT-2000+/64 General Info De ...

  6. zabbix基于容器化在UOS1050E上面的安装与使用

    前言 想着能够监控一下操作系统的日志. 因为国产化的需求, 所以我这边使用了UOS1050E 安装zabbix时多次提示缺少php-json 或者是缺少一些libevent等组件. 自己尝试进行解决发 ...

  7. ESXi重置密码以及修改网络IP地址的方法

    Study From https://www.cnblogs.com/mk21/p/15784082.html 前期公司有部分虚拟化的服务器因为只通过vCenter进行管理. 导致密码遗失. 最近因为 ...

  8. 如何抓取http请求/拦截器用法

    我们都知道postman是模拟接口向服务端发送请求的,在编写请求数据的时候非常 麻烦,那么如果我们可以先抓取该接口后直接使用,就方便的很多 抓取http请求 1.我们打开postman时就会看见右上角 ...

  9. 用Unity3D做游戏开发在Android上的常用调试方法

    Hdg Remote Debug 远程调试 游戏运行在手机上,可以通过pc端的unity来随时修改当前场景中GameObject的变量,从而改变手机上运行时的表现.比如,我可以勾掉下图中的" ...

  10. 用python进行精细中文分句(基于正则表达式),HarvestText:文本挖掘和预处理工具

    1.用python进行精细中文分句(基于正则表达式) 中文分句,乍一看是一个挺简单的工作,一般我们只要找到一个[.!?]这类的典型断句符断开就可以了吗.       对于简单的文本这个做法是已经可行了 ...