[TOC]
一、docker-compose.yml 示例
编写文件 docker-compose.yml
目录结构如下
docker-compose.yml
--eureka
----Dockerfile
----microservice-eureka-server-0.0.1-SNAPSHOT.jar
在docker-compose.yml文件添加内容
version: '2' #docker-compose.yml的文件格式版本
services:
eureka: #指定服务名,随便取
build: ./eureka #指定Dockerfile文件所在目录
ports:
- "8761:8761" #指定端口映射
expose:
- 8761 # 容器提供服务端口
docker-compose build
重新构建镜像
docker-compose up
运行所有容器。加上-d
参数表示后台运行容器,加上--build
参数表示运行容器前先重新构建镜像
docker-compose up -d --build
二、docker-compose.yml 常用指令
image
指定镜像名称或者镜像id,如果该镜像在本地不存在,Compose会尝试pull下来
示例:
image: java
container_name
指定容器的名称
build
指定Dockerfile文件的路径。若用此指令,则每次执行docker-compose up
都会构建镜像。
可以是一个路径,例如:
build: ./dir
也可以是一个对象,用以指定Dockerfile和参数,例如:
build:
context: ./dir
dockerfile: Dockerfile
args:
buildno: 1
command
覆盖容器启动后默认执行的命令
示例:
command: bundle exec thin -p 3000
也可以是一个list,类似于Dockerfile总的CMD指令,格式如下:
command: [bundle, exec, thin, -p, 3000]
links
链接到其他服务中的容器。可以指定服务名称和链接的别名使用SERVICE:ALIAS
的形式,或者只指定服务名称,示例:
web:
links:
- db
- db:database
- redis
external_links
表示链接到docker-compose.yml外部的容器,甚至并非Compose管理的容器,特别是对于那些提供共享容器或共同服务。格式跟links类似CONTAINER:ALIAS
,示例:
external_links:
- redis_1
- project_db_1:mysql
- project_db_1:postgresql
ports
暴露端口信息。使用宿主端口:容器端口
的格式,或者仅仅指定容器的端口(此时宿主机将会随机指定端口),类似于docker run -p ,示例:
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"
expose
暴露端口,只将端口暴露给连接的服务,而不暴露给宿主机,示例:
expose:
- "3000"
- "8000"
restart
容器的启动策略,有如下值可选:
- no:默认策略,在容器退出时不重启容器
- on-failure:容器非正常退出时(退出状态非0),才会重启容器
- on-failure:3,在容器非正常退出时重启容器,最多重启3次
- always:在容器退出时总是重启容器
volumes
卷挂载路径设置。可以设置宿主机路径 (HOST:CONTAINER) 或加上访问模式 (HOST:CONTAINER:ro)。示例:
volumes:
# Just specify a path and let the Engine create a volume
- /var/lib/mysql
# Specify an absolute path mapping
- /opt/data:/var/lib/mysql
# Path on the host, relative to the Compose file
- ./cache:/tmp/cache
# User-relative path
- ~/configs:/etc/configs/:ro
# Named volume
- datavolume:/var/lib/mysql
volumes_from
从另一个服务或者容器挂载卷。可以指定只读或者可读写,如果访问模式没有指定,则默认是可读写。示例:
volumes_from:
- service_name
- service_name:ro
- container:container_name
- container:container_name:rw
environment
设置环境变量。可以使用数组或者字典两种方式。只有一个key的环境变量可以在运行Compose的机器上找到对应的值,这有助于加密的或者特殊主机的值。示例:
environment:
RACK_ENV: development
SHOW: 'true'
SESSION_SECRET:
environment:
- RACK_ENV=development
- SHOW=true
- SESSION_SECRET
env_file
从文件中获取环境变量,可以为单独的文件路径或列表。如果通过 docker-compose -f FILE 指定了模板文件,则 env_file 中路径会基于模板文件路径。如果有变量名称与 environment 指令冲突,则以envirment 为准。示例:
env_file: .env
env_file:
- ./common.env
- ./apps/web.env
- /opt/secrets.env
extends
继承另一个服务,基于已有的服务进行扩展。
network_mode
设置网络模式。采用与docker--network
参数相同的值,添加了特殊格式service:[service name]
network_mode: "bridge"
network_mode: "host"
network_mode: "none"
network_mode: "service:[service name]"
network_mode: "container:[container name/id]"
networks
指定要加入的网络
services:
some-service:
networks:
- some-network
- other-network
dns
配置dns服务器。可以是一个值,也可以是一个列表。示例:
dns: 8.8.8.8
dns:
- 8.8.8.8
- 9.9.9.9
dns_search
配置DNS的搜索域,可以是一个值,也可以是一个列表,示例:
dns_search: example.com
dns_search:
- dc1.example.com
- dc2.example.com
三、参考文档
docker-compose文件官方文档
使用Spring Cloud与Docker实战微服务