#docker-compose.yml常用命令 **image** 指定镜像名称或者镜像id,如果该镜像在本地不存在,Compose会尝试pull下来。 示例: ``` image: java ``` **build** 指定Dockerfile文件的路径。可以是一个路径,例如: ``` build: ./dir ``` 也可以是一个对象,用以指定Dockerfile和参数,例如: ``` build: context: ./dir dockerfile: Dockerfile-alternate 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类似,示例: ``` 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" ``` **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** 继承另一个服务,基于已有的服务进行扩展。 **net** 设置网络模式。示例: ``` net: "bridge" net: "host" net: "none" net: "container:[service name or container name/id]" ``` **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 ```