docker-compose.yml配置文件参数

1. image

services:
  web:
    image: bitnami/mysql:5.7

在 services 标签下的第二级标签是 web,这个名字是用户自己自定义,它就是服务名称。
image 则是指定服务的镜像名称或镜像 ID。如果镜像在本地不存在,Compose 将会尝试拉取这个镜像。


2. environment
环境变量,这个标签的作用是设置镜像变量,它可以保存变量到镜像里面,也就是说启动的容器也会包含这些变量设置。
environment 和 Dockerfile 中的 ENV 指令一样会把变量一直保存在镜像、容器中,类似 docker run -e 的效果。

environment:
  RACK_ENV: development
  SHOW: 'true'
  SESSION_SECRET:

environment:
  - RACK_ENV=development
  - SHOW=true
  - SESSION_SECRET

3. networks
加入指定网络,格式如下:

services:
  some-service:
    networks:
     - some-network
     - other-network

关于这个标签还有一个特别的子标签aliases,这是一个用来设置服务别名的标签,例如:

services:
  some-service:
    networks:
      some-network:
        aliases:
         - alias1
         - alias3
      other-network:
        aliases:
         - alias2

相同的服务可以在不同的网络有不同的别名。


4. expose
与dockerfile中的expose一样,用来暴露指定的端口号

expose:
 - "80"
 - "8080"

5. ports
端口映射,把docker内部的端口暴露出来
使用HOST:CONTAINER格式或者只是指定容器的端口,宿主机会随机映射端口。

ports:
 - "3000"
 - "8000:8000"
 - "49100:22"
 - "127.0.0.1:8001:8001"

注意:当使用HOST:CONTAINER格式来映射端口时,如果你使用的容器端口小于60你可能会得到错误得结果,因为YAML将会解析xx:yy这种数字格式为60进制。所以建议采用字符串格式。


6.restart
重启操作

restart: "no"
restart: always
restart: on-failure
restart: unless-stopped

7. build
服务除了可以基于指定的镜像,还可以基于一份 Dockerfile,在使用 up 启动之时执行构建任务,这个构建标签就是 build,它可以指定 Dockerfile 所在文件夹的路径。Compose 将会利用它自动构建这个镜像,然后使用这个镜像启动服务容器。

build: /path/to/build/dir

也可以是相对路径,只要上下文确定就可以读取到 Dockerfile。

build: ./dir

设定上下文根目录,然后以该目录为准指定 Dockerfile。

build:   
    context: .   
    dockerfile: name.dockerfile

注意 build 都是一个目录,如果你要指定 Dockerfile 文件需要在 build 标签的子级标签中使用 dockerfile 标签指定,如上面的例子。
如果你同时指定了 image 和 build 两个标签,那么 Compose 会构建镜像并且把镜像命名为 image 后面的那个名字。

build: ./dir 
image: webapp:tag

8.depends_on

在使用 Compose 时,最大的好处就是少打启动命令,但是一般项目容器启动的顺序是有要求的,如果直接从上到下启动容器,必然会因为容器依赖问题而启动失败。
例如在没启动数据库容器的时候启动了应用容器,这时候应用容器会因为找不到数据库而退出,为了避免这种情况我们需要加入一个标签,就是 depends_on,这个标签解决了容器的依赖、启动先后的问题。
例如下面容器会先启动 redis 和 db 两个服务,最后才启动 web 服务:

version: '2'
services:
  web:
    build: .
    depends_on:
      - db
      - redis
  redis:
    image: redis
  db:
    image: postgres

注意的是,默认情况下使用 docker-compose up web 这样的方式启动 web 服务时,也会启动 redis 和 db 两个服务,因为在配置文件中定义了依赖关系。


9. volumes
挂载一个目录或者一个已存在的数据卷容器,可以直接使用 [HOST:CONTAINER] 这样的格式,或者使用 [HOST:CONTAINER:ro] 这样的格式,后者对于容器来说,数据卷是只读的,这样可以有效保护宿主机的文件系统。
Compose的数据卷指定路径可以是相对路径,使用 . 或者 … 来指定相对目录。
数据卷的格式可以是下面多种形式:

volumes:
  # 只是指定一个路径,Docker 会自动在创建一个数据卷(这个路径是容器内部的)。
  - /var/lib/mysql

  # 使用绝对路径挂载数据卷
  - /opt/data:/var/lib/mysql

  # 以 Compose 配置文件为中心的相对路径作为数据卷挂载到容器。
  - ./cache:/tmp/cache

  # 使用用户的相对路径(~/ 表示的目录是 /home/<用户目录>/ 或者 /root/)。
  - ~/configs:/etc/configs/:ro

  # 已经存在的命名的数据卷。
  - datavolume:/var/lib/mysql

#如果不使用宿主机的路径,可以指定一个volume_driver。
volume_driver: mydriver

示例:

volumes:
  - './nginx-config/party.conf:/etc/nginx/conf.d/party.conf'
  - './dist:/usr/share/nginx/party'
  - './party-static/:/usr/share/nginx/party-static/'
  - /etc/timezone:/etc/timezone             #配置时区        
  - /etc/localtime:/etc/localtime           #配置时区

docker-compose.yml文件:

services:
  mysql:
    image: 'bitnami/mysql:5.7'
    environment:
      - ALLOW_EMPTY_PASSWORD=no
      - MYSQL_ROOT_USER=root
      - MYSQL_ROOT_PASSWORD=123
      - MYSQL_DATABASE=web
      - MYSQL_USER=root
      - MYSQL_PASSWORD=123
      - MYSQL_AUTHENTICATION_PLUGIN=mysql_native_password
      - MYSQL_CHARACTER_SET=utf8mb4
      - MYSQL_COLLATE=utf8mb4_unicode_ci
    networks:
      - web_net
    expose:
      - '3306'
#    ports:
#      - '1433:1433'
    volumes:
      - 'mysql_data:/bitnami/mysql/data'
      - 'mysql_conf:/opt/bitnami/mysql/conf'
    restart: always
  web-backend:
    build:
      context: .
      dockerfile: web-backend.dockerfile
    image: 'web/web-backend'
     expose:
       - '8081'
    # environment:
    #   - TZ=Asia/Shanghai
#    ports:
#      - '8081:8081'
    depends_on:
      - mysql
    volumes:
      - /etc/timezone:/etc/timezone
      - /etc/localtime:/etc/localtime
      - './web-files:/web-files'
      - './web-folder:/web-folder'
    networks:
      - web_net
    restart: always
  web-front:
    image: 'nginx:stable-alpine'
    # environment:
    #   - TZ="Asia/Shanghai"
    ports:
      - '8083:81'
    depends_on:
      - web-backend
    volumes:
      - './nginx-config/web.conf:/etc/nginx/conf.d/web.conf'
      - './dist:/usr/share/nginx/web'
      - './web-static/:/usr/share/nginx/web-static/'
      - /etc/timezone:/etc/timezone
      - /etc/localtime:/etc/localtime
    networks:
      - web_net
    restart: always
networks:
  web_net:
    ipam:
      driver: default
      config:
        - subnet: "192.168.2.0/24"
volumes:
  mysql_data:
    driver: local
  mysql_conf:
    driver: local
  phpmyadmin_data:
    driver: local
  inet_user_data:
    driver: local
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Docker Compose 是 Docker 官方提供的一个工具,用于管理多个 Docker 容器的工具,通过一个配置文件来定义一组相关联的应用容器为一个项目。Docker Compose 配置文件 docker-compose.yml 是一个 YAML 格式的文件,用于定义多个容器的构建、启动和运行参数。 下面是一个 docker-compose.yml 配置文件的示例: ``` version: '3' services: web: build: . ports: - "5000:5000" volumes: - .:/code links: - redis redis: image: "redis:alpine" ``` 这个配置文件定义了两个服务:web 和 redis。web 服务基于 Dockerfile 构建镜像,将容器内部的 5000 端口映射到主机的 5000 端口,将当前目录挂载到容器的 /code 目录下,同时将 redis 服务链接到 web 服务中。redis 服务则直接使用官方提供的 redis:alpine 镜像。 在这个配置文件中,version 指定了 Docker Compose 的版本号。services 是一个列表,用于定义多个服务。每个服务定义了自己的构建、启动和运行参数。 在 services 列表中,每个服务都有一个名称,这个名称是用来区分服务的。例如,这个配置文件中的 web 服务就是一个名为 web 的容器。 build 表示使用 Dockerfile 构建镜像。ports 表示将容器内部的端口映射到主机的端口。volumes 表示将主机上的目录挂载到容器内部,使容器内部的数据可以持久化保存。links 表示将其他服务链接到当前服务中,以便它们之间可以相互通信。 除了上面的参数之外,还有其他一些参数可以用于配置 Docker Compose,例如 networks、volumes、environment 等等。详细的配置参数可以参考 Docker Compose 的官方文档。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值