docker-compose的yml文件中常用选项

1. 从一个示例说起

先看一下这个示例,先不用理解,因为接下来我们将解释其中各选项

version: '3'
services:
  auth:
    image: 'harbocto.xxx.com.cn/crust/crust-auth:1.0.0'
    restart: always
    container_name: auth
    networks:
      - crust-net
    volumes:
      - ./logs:/app/logs/
    ports:
      - '10001:10001'
    environment:
      JAVA_OPTS: "-Djava.security.egd=file:/dev/./urandom"
      WAIT_HOSTS: "redis:6379,postgre:5432,nacos:8848"
      NACOS_SERVER: "nacos:8848"
      NACOS_SERVER_USERNAME: "nacos"
      NACOS_SERVER_PASSWORD: "nacos"
  user:
    image: 'harbocto.xxx.com.cn/crust/crust-user:1.0.0'
    restart: always
    container_name: user
    networks:
      - crust-net
    volumes:
      - ./logs:/app/logs/
    ports:
      - '10002:10002'
    environment:
      JAVA_OPTS: "-Djava.security.egd=file:/dev/./urandom"
      WAIT_HOSTS: "redis:6379,postgre:5432,nacos:8848"
      NACOS_SERVER: "nacos:8848"
      NACOS_SERVER_USERNAME: "nacos"
      NACOS_SERVER_PASSWORD: "nacos"
  gateway:
    image: 'harbocto.xxx.com.cn/crust/crust-gateway:1.0.0'
    restart: always
    container_name: gateway
    depends_on:
    - auth
    networks:
      - crust-net
    volumes:
      - ./logs:/app/logs/
    ports:
      - '10000:10000'
    environment:
      JAVA_OPTS: "-Djava.security.egd=file:/dev/./urandom"
      WAIT_HOSTS: "auth:10001,redis:6379,postgre:5432,nacos:8848"
      NACOS_SERVER: "nacos:8848"
      NACOS_SERVER_USERNAME: "nacos"
      NACOS_SERVER_PASSWORD: "nacos"
networks:
 crust-net:
   external:
     name: postgre_crust-net

2. 常用选项

2.1 images

  • 作用: 指定镜像
  • 示例: 如 示例

2.2 restart

  • 作用: 容器重启策略
  • 示例:
restart: always

no,默认策略,在容器退出时不重启容器
on-failure,在容器非正常退出时(退出状态非0),才会重启容器
on-failure:3,在容器非正常退出时重启容器,最多重启3次
always,在容器退出时总是重启容器
unless-stopped,在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器

2.3 container_name

  • 作用: 给启动的容器命名
  • 示例:
    示例
container_name: auth

2.4 ports

  • 作用: 端口映射,将容器内端口映射到宿主机
  • 示例:
    ports:
     - 10002:10002
     - 10003:10003/udp

2.5 depends_on

  • 作用: 设置service之间的依赖

  • 示例:

version: '2'
services:
  user:
    build: .
    depends_on:
      - db
      - redis
  redis:
    image: redis
  db:
    image: postgre

说明:user服务依赖于db和redis。

2.6 volumes

  • 作用: 将容器中目录挂着到宿主机(宿主机覆盖容器中目录)
  • 示例:
    将容器中的 /app/logs 目录挂着到宿主机docker-compose所在目录的 logs目录。
    volumes:
      - ./logs:/app/logs/

2.7 environment

《docker-compose中变量的使用》

2.8 networks

《docker-compose网络》

2.9 command

  • 作用: 启动时执行的命令(将覆盖原有启动命令)

  • 示例:

command: ["/bin/sh","-c","while true;do echo hello;sleep 1;done"]

运行如下:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: docker-compose是一个用于定义和管理多个Docker容器的工具。它使用YAML(YAML Ain't Markup Language)格式的docker-compose.yml文件来描述应用程序的服务、网络和卷等配置。 docker-compose.yml文件由多个部分组成,包括版本、服务、网络和卷。 版本部分用来指定docker-compose所使用的格式版本,例如: ``` version: '3' ``` 服务部分是docker-compose.yml文件最重要的部分,用来定义需要运行的容器,包括镜像名称、容器名称、端口映射、环境变量等,例如: ``` services: web: image: nginx:latest ports: - "80:80" environment: - DEBUG=true ``` 网络部分用来定义容器之间的网络连接,例如: ``` networks: mynetwork: ``` 卷部分用来定义数据持久化的方式,例如: ``` volumes: myvolume: ``` 通过docker-compose.yml文件定义的服务、网络和卷等配置,可以方便地启动、停止、管理多个Docker容器。 除了上述基本语法外,docker-compose.yml文件还支持其他更高级的功能,如环境变量引用、扩展字段、容器依赖关系等。 总之,docker-compose.yml语法是用来描述和管理多个Docker容器的工具,可以通过定义版本、服务、网络和卷等配置来实现容器的启动、停止和管理。它使用YAML格式,具有简洁和易读性强的特点,方便开发者进行使用和维护。 ### 回答2: Docker Compose是一个用于定义和运行多个Docker容器的工具。它使用yml(YAML)语法来描述容器之间的关系、所需的映像、环境变量、端口绑定等信息。 在Docker Compose的yml文件,我们可以定义多个服务(services),每个服务对应一个容器。每个服务可以指定一个映像(image),即使用的基础镜像以及所需的标签或版本号。 除了映像,我们可以为每个服务指定容器名称(container_name)、挂载的卷(volumes)、环境变量(environment)、端口映射(ports)等。 在yml文件,可以使用"services"关键字来定义多个服务,每个服务都包括一个唯一的名称,以及下面的属性: - image: 指定使用的映像 - container_name: 指定容器的名称 - volumes: 指定挂载的卷 - environment: 指定环境变量 - ports: 指定端口映射 此外,我们还可以使用其他关键字来定义全局的配置选项,例如版本(version)、网络(networks)等。 版本指定了使用的Docker Compose yml文件的版本,可以使用1、2或3等不同版本。 网络定义了在Compose文件使用的网络配置,可以指定网络模式为bridge、host或user-defined。 除了上述基本的语法,还可以使用一些高级特性如依赖关系、资源限制、扩展等。 总之,Docker Compose yml语法提供了一种简洁且易于理解的方式来定义和管理多个Docker容器,使得我们能够轻松地创建和运行多个容器化的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

玄德公笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值