YML(2)yml 语法

YAML 语法

来源:yaml

这个页面提供一个正确的 YAML 语法的基本概述, 它被用来描述一个 playbooks(我们的配置管理语言).

我们使用 YAML 是因为它像 XML 或 JSON 是一种利于人们读写的数据格式. 此外在大多数变成语言中有使用 YAML 的库.

Attention

几个语法要点很简单,然而没有分号的语法需要注意缩进规则:同一层的变量要有相同的缩进,不然会将\t或\n当做字符串。注意空格。

基本的 YAML

对于 Ansible, 每一个 YAML 文件都是从一个列表开始. 列表中的每一项都是一个键值对, 通常它们被称为一个 “哈希” 或 “字典”. 所以, 我们需要知道如何在 YAML 中编写列表和字典.

YAML 还有一个小的怪癖. 所有的 YAML 文件(无论和 Ansible 有没有关系)开始行都应该是 ---. 这是 YAML 格式的一部分, 表明一个文件的开始.

列表中的所有成员都开始于相同的缩进级别, 并且使用一个 "- " 作为开头(一个横杠和一个空格):

---
# 一个美味水果的列表
- Apple
- Orange
- Strawberry
- Mango

一个字典是由一个简单的 键:  的形式组成(这个冒号后面必须是一个空格):

---
# 一位职工的记录
name: Example Developer
job: Developer
skill: Elite

字典也可以使用缩进形式来表示, 如果你喜欢这样的话:

---
# 一位职工的记录
{name: Example Developer, job: Developer, skill: Elite}

Ansible并不是太多的使用这种格式, 但是你可以通过以下格式来指定一个布尔值(true/fase):

---
create_key: yes
needs_agent: no
knows_oop: True
likes_emacs: TRUE
uses_cvs: false

让我们把目前所学到的 YAML 例子组合在一起. 这些在 Ansible 中什么也干不了, 但这些格式将会给你感觉:

---
# 一位职工记录
name: Example Developer
job: Developer
skill: Elite
employed: True
foods:
    - Apple
    - Orange
    - Strawberry
    - Mango
languages:
    ruby: Elite
    python: Elite
    dotnet: Lame

这就是你开始编写 Ansible playbooks 所需要知道的所有 YAML 语法.

Gotchas

尽管 YAML 通常是友好的, 但是下面将会导致一个 YAML 语法错误:

foo: somebody said I should put a colon here: so I did

你需要使用引号来包裹任何包含冒号的哈希值, 像这样:

foo: "somebody said I should put a colon here: so I did"

然后这个冒号将会被结尾.

此外, Ansible 使用 “{{ var }}” 来引用变量. 如果一个值以 “{” 开头, YAML 将认为它是一个字典, 所以我们必须引用它, 像这样:

foo: "{{ variable }}"
So do it,and change it,no regret!

转载于:https://www.cnblogs.com/lexiaofei/p/6806753.html

### 回答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、付费专栏及课程。

余额充值