Ansible 小手册系列 八(Yaml 语法格式)
YAML 语言(发音 /ˈjæməl/ )的设计目标,就是方便人类读写。它实质上是一种通用的数据串行化格式。
它的基本语法规则如下。
• 大小写敏感
• 使用缩进表示层级关系
• 缩进时不允许使用Tab键,只允许使用空格。
• 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
• yaml文件以"---"作为文档的开始,"..."作为文档的结束
#表示注释,从这个字符一直到行尾,都会被解析器忽略。
YAML 支持的数据结构有三种。
• 对象:键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 字典(dictionary)
• 数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)
• 纯量(scalars):单个的、不可再分的值
对象
对象的一组键值对,使用冒号结构表示。
job: Developer
列表
---
fruits:
- Apple
- Orange
- Strawberry
- Mango
转换为python格式
{'fruits': ['Apple', 'Orange', 'Strawberry', 'Mango']}
可以使用行内表示法
---
fruits: ['Apple', 'Orange', 'Strawberry', 'Mango']
字典
---
martin:
name: Martin D'vloper
job: Developer
skill: Elite
转换为python格式
{'martin': {'job': 'Developer', 'name': "Martin D'vloper", 'skill': 'Elite'}}
可以使用行业内表示法
---
martin: {name: Martin D'vloper, job: Developer, skill: Elite}
复合结构

转换为python格式
[{'martin': {'job': 'Developer','name': "Martin D'vloper",'skills': ['python', 'perl', 'pascal']}},{'tabitha': {'job': 'Developer', 'name': 'Tabitha Bitumen','skills': ['lisp', 'fortran', 'erlang']}}]
纯量
数值
number: 12
float:12.30
转换为python格式
{'float': 12.300000000000001, 'number': 12}
布尔值
表示true的值
true, True, TRUE, yes, Yes, YES, on, On, ON, y, Y
表示false的值
false, False, FALSE, no, No, NO, off, Off, OFF, n, N
转换数据类型
e: !!str 123
f: !!str true
转换为python格式
{'e': '123', 'f': 'true'}
字符串
# 字符串默认不使用引号表示。
str: 这是一行字符串
# 转换为python格式
{'str': '这是一行字符串'} # 单引号和双引号都可以使用,双引号不会对特殊字符转义。
# 如果字符串之中包含空格或特殊字符,需要放在引号之中。
str: '内容: 字符串'
# 转换为python格式
{'str': '内容: 字符串'} s1: '内容\n字符串'
s2: "内容\n字符串"
# 转换为python格式
{'s1': '内容\\n字符串','s2': '内容\n字符串'} # 单引号之中如果还有单引号,必须连续使用两个单引号转义。
str: 'labor''s day'
# 转换为python格式
{'str': "labor's day"} # 字符串可以写成多行,从第二行开始,必须有一个单空格缩进。换行符会被转为空格。
str: 这是一段
多行
字符串
# 转换为python格式
{'str': '这是一段 多行 字符串'} # 多行字符串可以使用|保留换行符,也可以使用>折叠换行。
this: |
Foo
Bar
that: >
Foo
Bar
# 转换为python格式
{'that': 'Foo Bar', 'this': 'Foo\nBar\n'} # +表示保留文字块末尾的换行,-表示删除字符串末尾的换行。
s1: |
Foo s2: |+
Foo s3: |-
Foo
# 转换为python格式
{'s1': 'Foo\n', 's2': 'Foo\n\n\n', 's3': 'Foo'} # 字符串之中可以插入 HTML 标记。
message: | <p style="color: red">
段落
</p>
# 转换为python格式
{'message': '\n<p style="color: red">\n 段落\n</p>'}
引用
# 锚点&和别名*,可以用来引用。
# &用来建立锚点(defaults),<<表示合并到当前数据,*用来引用锚点。
defaults: &defaults
adapter: postgres
host: localhost
development:
database: myapp_development
<<: *defaults
test:
database: myapp_test
<<: *defaults # 等同于下面的代码。
defaults:
adapter: postgres
host: localhost
development:
database: myapp_development
adapter: postgres
host: localhost
test:
database: myapp_
test adapter: postgres
host: localhost
# 转换为python格式
{'defaults': {'adapter': 'postgres', 'host': 'localhost'}, 'development': {'adapter': 'postgres', 'database': 'myapp_development', 'host': 'localhost'}, 'test': {'adapter': 'postgres', 'database': 'myapp_test', 'host': 'localhost'}} # 下面是另一个例子。
- &showell Steve
- Clark
- Brian
- Oren
- *showell
# 转换为python格式
['Steve', 'Clark', 'Brian', 'Oren', 'Steve']
yaml中引用变量
foo: "{{ variable }}"
高级YAML语法
!unsafe使用
# 变量值中保存的数据应被视为不安全的,防止不安全的字符子集和信息披露。
---
hosts: all
vars:
my_unsafe_variable: !unsafe 'unsafe value'
tasks:
...
Ansible 小手册系列 八(Yaml 语法格式)的更多相关文章
- Ansible 小手册系列 十八(Lookup 插件)
file:获取文件内容 --- - hosts: all vars: contents: "{{ lookup('file', '/etc/foo.txt') }}" tasks: ...
- Ansible 小手册系列 三(命令介绍)
仅仅只是介绍,可以选择跳过 ansible ansible是指令核心部分,其主要用于执行ad-hoc命令,即单条命令.默认后面需要跟主机和选项部分,默认不指定模块时,使用的是command模块. Us ...
- Ansible 小手册系列 十三(Jinja2)
用于playbook中的jinja 2过滤器 更改数据格式,其结果是字符串 {{ some_variable | to_json }} {{ some_variable | to_yaml }} 对于 ...
- Ansible 小手册系列 十一(变量)
变量名约束 变量名称应为字母,数字和下划线. 变量应始终以字母开头. 变量名不应与python属性和方法名冲突. 变量使用 通过命令行传递变量(extra vars) ansible-playbook ...
- Ansible 小手册系列 十四(条件判断和循环)
条件判断 When 语句 在when 后面使用Jinja2 表达式,结果为True则执行任务. tasks: - name: "shut down Debian flavored syste ...
- Ansible 小手册系列 二十(经常遇到的问题)
(1). 怎么为任务设置环境变量? - name: set environment shell: echo $PATH $SOME >> /tmp/a.txt environment: P ...
- Ansible 小手册系列 十二(Facts)
Facts 是用来采集目标系统信息的,具体是用setup模块来采集得. 使用setup模块来获取目标系统信息 ansible hostname -m setup 仅显示与ansible相关的内存信息 ...
- Ansible 小手册系列 十(包含和角色)
一.包含 (include) 使用include模块来包含foo文件 tasks: - include: foo.yml --- foo.yml - name: test foo command: e ...
- Ansible 小手册系列 九(Playbook)
playbook是由一个或多个"play"组成的列表.play的主要功能在于将事先归并为一组的主机装扮成事先通过ansible中的task定义好的角色.从根本上来讲所谓task无非 ...
随机推荐
- [转]VMware-Transport(VMDB) error -44:Message.The VMware Authorization Service is not running解决方案
转自:http://blog.sina.com.cn/s/blog_70c9c4b40101i01v.html 1.VMware Workstation中新建的虚拟机在开机的时候出现这种错误:Tran ...
- Scala List 用法
1.++[B] 在A元素后面追加B元素 scala> val a = List(1) a: List[Int] = List(1) scala> val b = List(2) b: ...
- 20145316《Java程序设计》第二周学习总结
20145316<Java程序设计>第2周学习总结 教材学习内容总结 3.1.1 Java的类型 分为基本类型(Primitive type)和类类型(Class type) 基本类型: ...
- 谷歌技术"三宝"之谷歌文件系统(转)
原文地址:http://blog.csdn.net/opennaive/article/details/7483523 题记:初学分布式文件系统,写篇博客加深点印象.GFS的特点是使用一堆廉价的商用计 ...
- Django学习笔记之URL标签的使用
期初用django 开发应用的时候,完全是在urls.py 中硬编码配置地址,在views.py中HttpResponseRedirect()也是硬编码转向地址,当然在template 中也是一样了, ...
- XPO开发指南简要
一.XPO简介: XPO即eXpress Persistent Objects for .NET,现在这里介绍的版本是1.5. XPO在应用程序代码和数据库之间扮演了一个中间层的角色,简单而言,就是将 ...
- ionic android - Unable to start the daemon process. Could not reserve enough space for 2097152KB object heap
Unzipping C:\Users\app\.gradle\wrapper\dists\gradle-4.1-all\bzyivzo6n839fup2jbap0tjew\gradle-4.1-all ...
- 20135302魏静静——linux课程第四周实验及总结
linux课程第四周实验及总结 一.实验 我选择的是第20号系统调用,getpid 代码如下: /* getpid.c */ #include <unistd.h> #include &l ...
- SVN 命令符号详解
L abc.c # svn已经在.svn目录锁定了abc.c M bar.c # bar.c的内容已经在本地修改过了 M baz.c # baz.c属性有修改,但没有内容修改 X 3rd_party ...
- Jackson 框架JSON、XML、List、Map直接相互转换
博客分类: json 参考:http://www.cnblogs.com/hoojo/archive/2011/04/22/2024628.html 在其基础上做了稍微调整 详情见附件 jacks ...