13.Kubernetes集群资源清单(YAML)
Kubernetes集群中对资源管理和资源对象编排部署都可以通过声明样式(YAML)文件来解决。
1.YAML介绍
YAML 是 “YAML Ain’t a Markup Language”(YAML 不是一种标记语言)的递归缩写。在开发的这种语言时,YAML 的意思其实是:“Yet Another Markup Language”(仍是一种标记语言)。特别适合用来表达或编辑数据结构、各种配置文件、倾印调试内容、文件大纲;以数据为中心。
YAML 的配置文件后缀为 .yml,如:runoob.yml
.
2.基本语法
大小写敏感
使用缩进表示层级关系
缩进不允许使用tab,只允许空格
缩进的空格数不重要,只要相同层级的元素左对齐即可
'#'表示注释
3.YAML支持的数据结构
(1)对象:键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 字典(dictionary)
对象键值对使用冒号结构表示 key: value,冒号后面要加一个空格。
也可以使用 key:{key1: value1, key2: value2, ...}
。
还可以使用缩进表示层级关系;
key:
child-key: value
child-key2: value2
较为复杂的对象格式,可以使用问号加一个空格代表一个复杂的 key,配合一个冒号加一个空格代表一个 value:
?
- complexkey1
- complexkey2
:
- complexvalue1
- complexvalue2
意思即对象的属性是一个数组 [complexkey1,complexkey2]
,对应的值也是一个数组 [complexvalue1,complexvalue2]
(2)数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)
以 - 开头的行表示构成一个数组:
- A
- B
- C
YAML 支持多维数组,可以使用行内表示:
key: [value1, value2, ...]
数据结构的子成员是一个数组,则可以在该项下面缩进一个空格。
-
- A
- B
- C
例如(复杂):
companies:
-
id: 1
name: company1
price: 200W
-
id: 2
name: company2
price: 500W
意思是 companies 属性是一个数组,每一个数组元素又是由 id、name、price 三个属性构成。
数组也可以使用流式(flow)的方式表示:
companies: [{id: 1,name: company1,price: 200W},{id: 2,name: company2,price: 500W}]
数组和对象可以构成复合结构,例:
languages:
- Ruby
- Perl
- Python
websites:
YAML: yaml.org
Ruby: ruby-lang.org
Python: python.org
Perl: use.perl.org
转换为 json 为:
{
languages: [ 'Ruby', 'Perl', 'Python'],
websites: {
YAML: 'yaml.org',
Ruby: 'ruby-lang.org',
Python: 'python.org',
Perl: 'use.perl.org'
}
}
(3)纯量(scalars):单个的、不可再分的值
纯量是最基本的,不可再分的值,包括:
字符串
str: hello
字符串默认不使用引号表示
字符串之中包含空格或特殊字符,需要放在引号之中
布尔值
isSet: true
整数
number: 12
浮点数
number: 12.30
Null
parent: ~
时间
日期
date: 1976-07-31
YAML允许使用两个感叹号,强制转换数据类型
e: !!str 123
f: !!ser ture
4.资源清单描述
在Kubernetes中,一般使用ymal格式的文件来创建符合我们预期期望的pod,这样的yaml文件称为资源清单。
(1)常用字段
参数名 | 字段类型 | 说明 |
---|---|---|
version | String | 这里指Kubernetes API的版本,基本上是v1,可以用kubectl api-version命令查看 |
kind | String | 文件定义的资源类型和角色,如:pod |
metadata | Object | 元数据对象,固定 |
metadata.name | String | 元数据对象的名字,如命名pod的名字 |
Spec | Object | 详细定义对象,固定值为Spec |
spec.containers[] | list | Spec对象的容器列表定义 |
spec.containers[].name | String | 定义容器的名字 |
spec.containers[].image | String | 定义要用的吗镜像名称 |
spec.containers[].imagePullPolicy | String | 定义镜像拉取策略,有Always(每次都尝试重新拉取镜像),Never(仅使用本地镜像),IfNotPresent(使用本地镜像,没有就拉取在线镜像)三个值可选。默认Always。 |
还有很多,这里就不一一叙述了!
(2)案例
例1:创建一个namespace
vi create-namespace
apiVersion: v1
kind: Namespace
metadata:
name: test
例2:创建一个pod
vi create-pod
apiVersion: v1
kind: Pod
metadata:
name: pod1
spec:
containers:
- name: nginx-containers
image: nginx: latest
其他博客:
Kubernetes技术极速入门(一)---- 初次见面,请多多关照
Kubernetes技术极速入门(二)----初次交锋,请手下留情
Kubernetes技术极速入门(三)---- 我有神器,能赢不
Kubernetes技术极速入门(五)----再来,我必定胜你
Kubernetes技术极速入门(六)---- 我搬救兵,等我回来
Kubernetes技术极速入门(七)---- 我又带了把神器
Kubernetes技术极速入门(八)---- 挥挥手,不带走一片云彩
感谢大家,点赞,收藏,关注,评论!