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
示例:文章来源:https://www.toymoban.com/news/detail-498444.html
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文件:文章来源地址https://www.toymoban.com/news/detail-498444.html
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
到了这里,关于docker-compose.yml配置文件参数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!