docker-compose基本语法

1、image

指定镜像

image: ubuntu:14.04

2、buildc

指定Dockerfile的路径创建镜像compose基于这个镜像启动服务容器

build: /path/to/build/dir

3、command

替换当前镜像默认启动的命令

command: bundle exec thin -p 3000

# ==

command: [bundle,exec,thin,-p,3000]

4、container_name:<项目名称><服务名称><序号> (容器名)

container_name: app (自定义项目名字)

5、depends_on

定义依赖关联

version: '2'

services:

web:

build: .

depends_on:

1 - db

- redis

redis:

image: redis

db:

image: postgres

6、dns

dns: 8.8.8.8

dns:

- 8.8.8.8

- 9.9.9.9

7、tmpfs

定义临时目录,容器关闭后会被删除

tmpfs: /run

tmpfs:

- /run

- /tmp

8、 entrypoint

替换容器启动默认命令

entrypoint: /code/entrypoint.sh

9、env_file

定义当前环境变量的文件,格式必须是key=value(需要调用文件)

env_file: .env

env_file:

- ./common.env

- ./apps/web.env

- /opt/secrets.env

10、environment:镜像变量,(可以直接定义)

environment:

RACK_ENV: development

SHOW: 'true'

SESSION_SECRET:

environment:

- RACK_ENV=development

- SHOW=true

- SESSION_SECRET

11、expose

定义比较重要的端口,不代表外界可以访问该端口,

expose:

- "3000"

- "8000"

12、 external_links:链接外部容器

docker-compose会创建一个新的网桥,使各个项目之间不能通信,但需要读取访

1 问其他项目的一些信息时,则需要使用external_links调用

external_links:

- redis_1

- project_db_1:mysql

- project_db_1:postgresql

13、extra_hosts

添加hosts记录

extra_hosts:

- "somehost:162.242.195.82"

- "otherhost:50.31.209.229"

14、labels - docker-swarm

用于集群化,docker-compose多用于单机部署

labels:

com.example.description: "Accounting webapp"

com.example.department: "Finance"

com.example.label-with-empty-value: ""

labels:

- "com.example.description=Accounting webapp"

- "com.example.department=Finance"

- "com.example.label-with-empty-value"

15、links

与 Docker client 的 --link 一样效果,会连接到其它服务中的容器

links:

- db

- db:database

- redis

16、 logging

默认日志存放位置:/var/ib/docker/container

logging:

driver: syslog

options:

syslog-address: "tcp://192.168.0.42:123"

17、pid

pid: "host"

18、port

ports: - "3000" 物理机的随机端口映射到容器的3000端口

- "8000:8000" 访问物理机的8000,访问到容器的8000

- "49100:22" 访问物理机的8000,访问到容器的8000

- "127.0.0.1:8001:8001" 仅允许通过回环地址访问

19、security_opt

单机部署没有意义

# 为每个容器覆盖默认的标签。简单说来就是管理全部服务的标签。比如设置全

部服务的user标签值为USER。

1 :

- label:user:USER

- label:role:ROLE

20、 stop_signal

信号

stop_signal: SIGUSR1

21、volumes

volumes:

// 只是指定一个路径,Docker 会自动在创建一个数据卷(这个路径是容器内

部的)。

- /var/lib/mysql

// 使用绝对路径挂载数据卷

- /opt/data:/var/lib/mysql

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

- ./cache:/tmp/cache

// 使用用户的相对路径(~/ 表示的目录是 /home/<用户目录>/ 或者

/root/)。

- ~/configs:/etc/configs/:ro

// 已经存在的命名的数据卷。

- datavolume:/var/lib/mysql

22、volumes_from:从其它容器或者服务挂载数据卷,可选的参数是 :ro或

者 :rw,前者表示容器只读,后者表示容器对数据卷是可读可写的。默认情况下

是可读可写的

volumes_from:

- service_name

- service_name:ro

- container:container_name

- container:container_name:rw

23、cap_add, cap_drop

添加权限

cap_add:

- ALL

cap_drop:

- NET_ADMIN

- SYS_ADMIN

--cap-add Add Linux capabilities

--cap-drop Drop Linux capabilities

--privileged Give extended privileges to this container(给root权限)

--device=[] Allows you to run devices inside the container without

the --privileged flag.

SYS_MODULE Load and unload kernel modules.

SYS_RAWIO Perform I/O port operations (iopl(2) and ioperm(2)).

SYS_PACCT Use acct(2), switch process accounting on or off.

SYS_ADMIN Perform a range of system administration operations.

SYS_NICE Raise process nice value (nice(2), setpriority(2)) and

change the nice value for arbitrary processes.

SYS_RESOURCE Override resource Limits.

SYS_TIME Set system clock (settimeofday(2), stime(2), adjtimex(2));

set real-time (hardware) clock.

SYS_TTY_CONFIG Use vhangup(2); employ various privileged ioctl(2)

operations on virtual terminals.

AUDIT_CONTROL Enable and disable kernel auditing; change auditing

filter rules; retrieve auditing status and filtering rules.

MAC_ADMIN Allow MAC configuration or state changes. Implemented for

the Smack LSM.

MAC_OVERRIDE Override Mandatory Access Control (MAC). Implemented

for the Smack Linux Security Module (LSM).

NET_ADMIN Perform various network-related operations.

SYSLOG Perform privileged syslog(2) operations.

DAC_READ_SEARCH Bypass file read permission checks and directory

read and execute permission checks.

LINUX_IMMUTABLE Set the FS_APPEND_FL and FS_IMMUTABLE_FL i-node

flags.

NET_BROADCAST Make socket broadcasts, and listen to multicasts.IPC_LOCK Lock memory (mlock(2), mlockall(2), mmap(2), shmctl(2)).IPC_OWNER Bypass permission checks for operations on System V IPCobjects.

SYS_PTRACE Trace arbitrary processes using ptrace(2).SYS_BOOT Use reboot(2) and kexec_load(2), reboot and load a newkernel for later execution.

LEASE Establish leases on arbitrary files (see fcntl(2)).WAKE_ALARM Trigger something that will wake up the system.BLOCK_SUSPEND Employ features that can block system suspend.

24、extends

链接一个子文件,类似于incloud

extends:

file: common.yml

service: webapp

25、network_mode

network_mode: "bridge"

network_mode: "host"

network_mode: "none"

network_mode: "service:[service name]"

network_mode: "container:[container name/id]"

26、 networks

services:

1some-service:

networks:

- some-network

- other-network

  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值