Docker系列教程22-docker-compose.yml常用命令
原文:http://www.itmuch.com/docker/22-docker-compose-yml-commands/ ,转载请注明出处。
docker-compose.yml是Compose的默认模板文件。该文件有多种写法,例如Version 1 file format、Version 2 file format、Version 2.1 file format、Version 3 file format等。其中,Version 1 file format将逐步被被弃用;Version 2.x及Version 3.x基本兼容,是未来的趋势。考虑到目前业界的使用情况,本节只讨论Version 2 file format下的常用命令。
(1) build
配置构建时的选项,Compose会利用它自动构建镜像。build的值可以是一个路径,例如:
build: ./dir
也可以是一个对象,用于指定Dockerfile和参数,例如:
build: context: ./dir dockerfile: Dockerfile-alternate args: buildno: 1
(2) command
覆盖容器启动后默认执行的命令。示例:
command: bundle exec thin -p 3000
也可以是一个list,类似于Dockerfile中的CMD指令,格式如下:
command: [bundle, exec, thin, -p, 3000]
(3) dns
配置dns服务器。可以是一个值,也可以是一个列表。示例:
dns: 8.8.8.8 dns: - 8.8.8.8 - 9.9.9.9
(4) dns_search
配置DNS的搜索域名,可以是一个值,也可以是一个列表。示例:
dns_search: example.com dns_search: - dc1.example.com - dc2.example.com
(5) environment
环境变量设置,可使用数组或字典两种方式。示例:
environment: RACK_ENV: development SHOW: 'true' SESSION_SECRET: environment: - RACK_ENV=development - SHOW=true - SESSION_SECRET
(6) env_file
从文件中获取环境变量,可指定一个文件路径或路径列表。如果通过 docker-compose -f FILE
指定了Compose文件,那么env_file中的路径是Compose文件所在目录的相对路径。使用environment指定的环境变量会覆盖env_file指定的环境变量。示例:
env_file: .env env_file: - ./common.env # 共用 - ./apps/web.env # web用 - /opt/secrets.env # 密码用
(7) expose
暴露端口,只将端口暴露给连接的服务,而不暴露给宿主机。示例:
expose: - "3000" - "8000"
(8) external_links
连接到docker-compose.yml外部的容器,甚至并非Compose管理的容器,特别是提供共享或公共服务的容器。格式跟links类似,例如:
external_links: - redis_1 - project_db_1:mysql - project_db_1:postgresql
(9) image
指定镜像名称或镜像id,如果本地不存在该镜像,Compose会尝试下载该镜像。
示例:
image: java
(10) links
连接到其他服务的容器。可以指定服务名称和服务别名( SERVICE:ALIAS
),也可只指定服务名称。例如:
web: links: - db - db:database - redis
(11) networks
详见本书《Docker Compose网络设置》一节。
(12) network_mode
设置网络模式。示例:
network_mode: "bridge" network_mode: "host" network_mode: "none" network_mode: "service:[service name]" network_mode: "container:[container name/id]"
(13) ports
暴露端口信息,可使用HOST:CONTAINER
的格式,也可只指定容器端口(此时宿主机将会随机选择端口),类似于docker run -p
。
需要注意的是,当使用HOST:CONTAINER
格式映射端口时,容器端口小于60将会得到错误的接口,因为yaml会把xx:yy
的数字解析为60进制。因此,建议使用字符串的形式。示例:
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"
(14) 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
(15) volumes_from
从另一个服务或容器挂载卷。可指定只读(ro)或读写(rw),默认是读写(rw)。示例:
volumes_from: - service_name - service_name:ro - container:container_name - container:container_name:rw
TIPS
(1) docker-compose.yml还有很多其他命令,比如depends_on、pid、devices等。限于篇幅,笔者仅挑选常用的命令进行讲解,其他命令不作赘述。感兴趣的读者们可参考官方文档:https://docs.docker.com/compose/compose-file/ 。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
网络模型 - 每天5分钟玩转 Docker 容器技术(169)
本节我们讨论 Kubernetes 网络这个重要主题。 Kubernetes 作为编排引擎管理着分布在不同节点上的容器和 Pod。Pod、Service、外部组件之间需要一种可靠的方式找到彼此并进行通信,Kubernetes 网络则负责提供这个保障。本章包括如下内容: Kubernetes 网络模型 各种网络方案 Network Policy Kubernetes 网络模型 Kubernetes 采用的是基于扁平地址空间的网络模型,集群中的每个 Pod 都有自己的 IP 地址,Pod 之间不需要配置 NAT 就能直接通信。另外,同一个 Pod 中的容器共享 Pod 的 IP,能够通过localhost通信。 这种网络模型对应用开发者和管理员相当友好,应用可以非常方便地从传统网络迁移到 Kubernetes。每个 Pod 可被看作是一个个独立的系统,而 Pod 中的容器则可被看做同一系统中的不同进程。 下面讨论在这个网络模型下集群中的各种实体如何通信。知识点前面都已经涉及,这里可当做复习和总结。 Pod 内容器之间的通信 当 Pod 被调度到某个节点,Pod 中的所有容器都在这个节点上运...
- 下一篇
Docker系列教程23-docker-compose常用命令
原文:http://www.itmuch.com/docker/23-docker-compose-commands/,转载请注明出处。 和docker命令一样,docker-compose命令也有很多选项。下面我们来详细探讨docker-compose的常用命令。 build 构建或重新构建服务。服务被构建后将会以project_service 的形式标记,例如:composetest_db 。 help 查看指定命令的帮助文档,该命令非常实用。docker-compose所有命令的帮助文档都可通过该命令查看。 docker-compose help COMMAND 示例: docker-compose help build # 查看docker-compose build的帮助 kill 通过发送SIGKILL 信号停止指定服务的容器。示例: docker-compose kill eureka 该命令也支持通过参数来指定发送的信号,例如: docker-compose kill -s SIGINT logs 查看服务的日志输出。 port 打印绑定的公共端口。示例: docker...
相关文章
文章评论
共有0条评论来说两句吧...