附005.Docker Compose文件详解
一 Docker Compose文件简介
- version:用于指定当前docker-compose.yml语法遵循哪个版本
- services:服务,在它下面可以定义应用需要的一些服务,每个服务都有自己的名字、使用的镜像、挂载的数据卷、所属的网络、依赖哪些其他服务等等。
- networks:应用的网络,在它下面可以定义应用的名字、使用的网络类型等。
- volumes:数据卷,在它下面可以定义数据卷,然后挂载到不同的服务下去使用。
二 Docker Compose文件详解
2.1 version字段
|
Compose文件格式
|
Docker Engine版本
|
|
3.7
|
18.06.0+
|
|
3.6
|
18.02.0+
|
|
3.5
|
17.12.0+
|
|
3.4
|
17.09.0+
|
|
3.3
|
17.06.0+
|
|
3.2
|
17.04.0+
|
|
3.1
|
1.13.1+
|
|
3.0
|
1.13.0+
|
|
2.4
|
17.12.0+
|
|
2.3
|
17.06.0+
|
|
2.2
|
1.13.0+
|
|
2.1
|
1.12.0+
|
|
2.0
|
1.10.0+
|
|
1.0
|
1.9.1.+
|
2.2 services区域
version: '3'
services:
webapp:
build: ./dir
image: webapp:tag
web:
links:
- db
- db:database
- redis
172.17.2.100 db
172.17.2.100 database
172.17.2.100 redis
external_links:
- redis_1
- project_db_1:mysql
- project_db_1:postgresql
ports:
- "3000"
- "3000-3005"
- "8000:8000"
- "9090-9091:8080-8081"
- "49100:22"
- "127.0.0.1:8001:8001"
- "127.0.0.1:5000-5010:5000-5010"
- "6060:6060/udp"
ports:
- target: 80
published: 8080
protocol: tcp
mode: host
- target:容器内的端口
- published:公开暴露的港口
- protocol:端口协议(tcp或udp)
- mode:host用于在每个节点上发布主机端口,或者ingress用于负载平衡的群集模式端口。
expose:
- "3000"
- "8000"
environment:
RACK_ENV: development
SHOW: 'true'
SESSION_SECRET:
environment:
- RACK_ENV=development
- SHOW=true
- SESSION_SECRET
env_file: .env env_file:
- ./common.env
- ./apps/web.env
- /opt/secrets.env
services:
some-service:
env_file:
- a.env
- b.env
version: '3'
services:
web:
build: .
depends_on:
- db
- redis
redis:
image: redis
db:
image: postgres
- docker-compose up:以依赖顺序启动服务,在以上示例中,db和redis之在web之前启动。
- docker-compose up SERVICE:自动包含SERVICE依赖项。在以上示例中,docker-compose up web还创建并启动db和redis。
version: '3'
services:
redis:
image: redis:alpine
deploy:
labels:
com.example.description: "This label will appear on all containers for the web service"
resources:
limits:
cpus: '0.50'
memory: 50M
reservations:
cpus: '0.25'
memory: 20M
replicas: 6
update_config:
parallelism: 2
delay: 10s
update_config:
parallelism: 2
delay: 10s
order: stop-first
restart_policy:
condition: on-failure
delay: 5s
max_attempts: 3
window: 120s
- condition:其中之一none,on-failure或any(默认:) any。
- delay:重新启动尝试之间等待的时间,指定为持续时间(默认值:0)。
- max_attempts:在放弃之前尝试重新启动容器的次数(默认值:永不放弃)。如果在配置中未成功重新启动 window,则此尝试不会计入配置的max_attempts值。例如,如果max_attempts设置为“2”,并且第一次尝试时重新启动失败,则可能会尝试重新启动两次以上。
- window:在决定重启是否成功之前等待多长时间,指定为持续时间(默认值:立即决定)。
- parallelism:一次回滚的容器数。如果设置为0,则所有容器同时回滚。
- delay:每个容器组的回滚之间等待的时间(默认为0)。
- failure_action:如果回滚失败该怎么办。一个continue或pause(默认pause)
- monitor:每次更新任务后的持续时间以监视失败(ns|us|ms|s|m|h)(默认为0)。
- max_failure_ratio:回滚期间容忍的失败率(默认值为0)。
- order:回滚期间的操作顺序。其中之一stop-first(旧任务在启动新任务之前停止),或者start-first(首先启动新任务,并且正在运行的任务暂时重叠)(默认stop-first)。
- parallelism:一次更新的容器数。
- delay:更新一组容器之间的等待时间。
- failure_action:更新失败时的行为。其中一个continue,rollback或者pause (默认:pause)。
- monitor:每次更新任务后的持续时间以监视失败(ns|us|ms|s|m|h)(默认为0)。
- max_failure_ratio:更新期间容忍的故障率。
- order:更新期间的操作顺序。其中一个stop-first(旧任务在启动新任务之前停止),或者start-first(首先启动新任务,并且正在运行的任务暂时重叠)(默认stop-first)注意:仅支持v3.4及更高版本。
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost"]
interval: 1m30s
timeout: 10s
retries: 3
start_period: 40s
network_mode: "bridge"
network_mode: "host"
network_mode: "none"
network_mode: "service:[service name]"
network_mode: "container:[container name/id]"
dns: 8.8.8.8
dns:
- 8.8.8.8
- 9.9.9.9
2.3 networks区域
version: "3"
services:
web:
build: .
ports:
- "8000:8000"
db:
image: postgres
ports:
- "8001:5432"
- 创建了一个名为myapp_default的网络。
- 使用web配置创建容器,在web下加入myapp_default网络。
- 使用db配置创建容器,在db下加入myapp_default网络。
version: '2' services:
app:
image: busybox
command: ifconfig
networks:
app_net:
ipv4_address: 172.16.238.10 networks:
app_net:
driver: bridge
enable_ipv6: true
ipam:
driver: default
config:
- subnet: 172.16.238.0/24
gateway: 172.168.238.254
2.4 volumes区域
version: "3"
services:
db:
image: db
volumes:
- data-volume:/var/lib/db
backup:
image: backup-service
volumes:
- data-volume:/var/lib/backup/data
volumes:
data-volume:
附005.Docker Compose文件详解的更多相关文章
- 附003.Docker Compose命令详解
一 Docker Compose命令格式 Usage: docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...] docker- ...
- Docker Compose文件详解 V2
Compose file reference 语法: web: build: ./web ports: - "5000:5000" volu ...
- Docker Compose配置文件详解(V3)
Docker Compose配置文件是Docker Compose的核心,用于定义服务.网络和数据卷.格式为YAML,默认路径为./docker-compose.yml,可以使用.yml或.yaml扩 ...
- Docker Compose 配置文件详解
先来看一份 docker-compose.yml 文件,不用管这是干嘛的,只是有个格式方便后文解说: version: '2' services: web: image: dockercloud/he ...
- docker entrypoint入口文件详解
docker entrypoint入口文件详解 pasting Dockerfile创建自定义Docker镜像以及CMD与ENTRYPOINT指令的比较 [k8s]args指令案例-彻底理解docke ...
- Docker学习(六)——Dockerfile文件详解
Docker学习(六)--Dockerfile文件详解 一.环境介绍 1.Dockerfile中所用的所有文件一定要和Dockerfile文件在同一级父目录下,可以为Dockerfile父目录的子目录 ...
- k8s之yaml文件详解
k8s之yaml文件详解 目录 k8s之yaml文件详解 1. k8s支持的文件格式 2. YAML语言格式 3. 查看api资源版本标签 4. 编写nginx-test.yaml资源配置清单 4.1 ...
- web.xml文件详解
web.xml文件详解 Table of Contents 1 listener. filter.servlet 加载顺序 2 web.xml文件详解 3 相应元素配置 1 listener. f ...
- Linux中/proc目录下文件详解
转载于:http://blog.chinaunix.net/uid-10449864-id-2956854.html Linux中/proc目录下文件详解(一)/proc文件系统下的多种文件提供的系统 ...
随机推荐
- Servlet.service() for servlet jsp threw exception
报错信息如下: org.apache.catalina.core.ApplicationDispatcher invoke 严重: Servlet.service() for servlet jsp ...
- mongodb系列~关于双活状态的mongodb集群
一简介:说说我们异地双活的集群 二 背景:需要建立异地双活的架构 三 构建 1 需要保证第二机房至少两个副本集DB,这样在第一机房挂掉后才能保证第二机房的可用性 2 集群状态下第二机房启用config ...
- mysql 查询优化~join算法
一简介:参考了几位师兄,尤其是M哥大神的博客,让我恍然大悟,赶紧记录下二 原理: mysql的三种算法 1 Simple Nested-Loop Join 将驱动表/外部表的结果集作为循环基础数据,然 ...
- Java的IO流——(七)
目录结构:
- Word打开默认显示缩略图,而不是文档结构图
So easy! 1.打开Word文档,点击缩略图右侧的"X",关闭缩略图: 2.打开菜单[视图],勾选"文档结构图": 3.关闭当前Word文档: 4.再次打 ...
- mybatis主键自增长
在数据库中建序列:SEQ_T_RESOURCE 第一种:会在传入该方法的的参数集合中添加主键元素,相当于:map.put("RES_ID",xxx); <insert id= ...
- PYTHON-函数对象,嵌套,名称空间与作用域,闭包函数
一 函数是第一类对象,即函数可以当作数据传递 1 可以被引用 2 可以当作参数传递 3 返回值可以是函数 3 可以当作容器类型的元素 def foo(): return len f = foo pri ...
- 洛谷P1638逛画展
传送门啦 只需记录满足条件的一个区间的初始端点 $ (head, tail) $ ,不断删掉左端点 $ head $ ,不断更新右端点 $ tail $ : 开一个 $ vis[] $ 记录一下每幅画 ...
- PHP接口继承及接口多继承原理与实现方法详解
在PHP的接口中,接口可以继承接口.虽然PHP类只能继承一个父类(单继承),但是接口和类不同,接口可以实现多继承,可以继承一个或者多个接口.当然接口的继承也是使用extends关键字,要多个继承的话只 ...
- java ServerSocket
public Socket accept() //等待连接,该方法阻塞 public void close() //关闭服务器套接字 ServerSocket只连一次的程序 /* this is se ...