yaml文件需注意的格式

1 什么是yaml

YAML 是 “YAML Ain’t a Markup Language”(YAML 不是一种标记语言)的缩写。YAML 的语法和其他高级语言类似,并且可以简单表达清单、散列表,标量等数据形态。它使用空白符号缩进和大量依赖外观的特色,适合用来表达或编辑数据结构、各种配置文件、倾印调试内容、文件大纲。YAML 的配置文件后缀为 .yml,如:nginx.yml 。

什么是标记语言?
标记语言,是一种将文本以及文本相关的其他信息结合起来,展现出关于文档结构和数据处理细节的电脑文字编码。与文本相关的其他信息(包括文本的结构和表示信息等)与原来的文本结合在一起,但是使用标记进行标识。标记语言不仅仅是一种语言,就像许多语言一样,它需要一个运行时环境,使其有用。提供运行时环境的元素称为用户代理。如html,markdown。
json也是非标记语言

2 yaml的基本规则

1、大小写敏感
2、使用缩进表示层级关系
3、禁止使用tab缩进,只能使用空格键
4、缩进长度没有限制,只要元素对齐就表示这些元素属于一个层级。
5、使用#表示注释
6、字符串可以不用引号标注

3 数据类型

YAML 支持以下几种数据类型:
1 键值对
键值对又称为映射(mapping)、哈希(hashes)、字典(dictionary), 键值对对象使用冒号结构表示 key: value,冒号后面要加一个空格。也可以使用 key:{key1: value1, key2: value2, …},可以使用缩进表示层级关系,同一缩进的所有键值对属于一个层级;

key: 
    child-key: value
    child-key2: value2

2 数组
数组是一组按次序排列的值,又称为序列(sequence) 、列表(list),使用连字符(-)加空格表示。

- one
- two
- three

3 纯量
纯量(scalars):纯量是最基本的,不可再分的值,包括:

  • 字符串
  • 布尔值
  • 整数
  • 浮点数
  • Null
  • 时间
  • 日期
boolean: 
    - TRUE  #true,True都可以
    - FALSE  #false,False都可以
float:
    - 3.14
    - 6.8523015e+5  #可以使用科学计数法
int:
    - 123
    - 0b1010_0111_0100_1010_1110    #二进制表示
null:
    nodeName: 'node'
    parent: ~  #使用~表示null
string:
    - 哈哈
    - 'Hello world'  #可以使用双引号或者单引号包裹特殊字符
    - newline
      newline2    #字符串可以拆成多行,每一行会被转化成一个空格
date:
    - 2018-02-17    #日期必须使用ISO 8601格式,即yyyy-MM-dd
datetime: 
    -  2018-02-17T15:02:31+08:00    #时间使用ISO 8601格式,时间和日期之间使用T连接,最后使用+代表时区

4 复合结构

键值对的元素不仅可以是纯量,也可以是键值对或者列表。列表的元素也可以是列表或键值对。那么字典和列表组合起来就有四种复合结构。

# 键值对套键值对
capital: 
	China: beijing
	America: DC
# 键值对套列表
country: 
    - beijing
    - shanghai
# 列表套列表
-
  - Ruby
  - Perl
  - Python 
- 
  - c
  - c++
  - java
# 列表套键值对
-
  id: 123
  name: zhangsan
-
  id: 124
  name: lisi 

5 特殊的写法

比如在k8s中部署一个pod的yaml会有下面这种情况:

spec:
  containers:
  - name: nginx
    image: nginx
    ports:
    - containerPort: 80

起初这里containers的值没有缩进困扰着我,containers为键,其值应该缩进,但没有缩进。为什么呢,经过测试,yaml缩进没有规定空格数,只要对其就可以。这里字典的值是列表,不缩进也能区分,可以不缩进,也就是和下面的写法一样。

spec:
  containers:
	  - name: nginx
	    image: nginx
	    ports:
	    - containerPort: 80

这种写法可能看起来更清楚一点,可以在yaml转json中测试,两者数据结构相同。我觉得写成后者看起来舒服一点。
那么问题来了,字典套列表可以省略缩进,那其他三种复合结构可以省略吗?
比如字典套字典

capital: 
	China: beijing
	America: DC
# 省略缩进
capital: 
China: beijing
America: DC

这两种表示的不是同一个意思,转化为json分别是:

{
  "capital": {
    "China": "beijing",
    "America": "DC"
  }
}
# 省略缩进
{
  "capital": null,
  "China": "beijing",
  "America": "DC"
}

经过测试,列表套列表,列表套字典也都不能省略缩进。

6 引用

& 用来建立锚点(defaults),<< 表示合并到当前数据,* 用来引用锚点。
比如:

info: 
  id:  001
  name:   zhangsan

moreinfo:
  birthplace : China
  id:  001
  name:   zhangsan

有一部分信息是重复的,相当于:

info: & myinfo
  id:  001
  name:   zhangsan

moreinfo:
  birthplace : China
  <<: * myinfo

总结:yaml文件少一个空格都可能出错,之前一直完全按照模板来写,但不知道为什么这里有空格或者什么时候缩进,还是容易出错,理解之后会好很多。
参考文献:
https://www.runoob.com/w3cnote/yaml-intro.html

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值