Kubernetes技术极速入门(四)---- 太强了,干不过
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技术极速入门(八)---- 挥挥手,不带走一片云彩
感谢大家,点赞,收藏,关注,评论!
 
                    
                     
                    
                 
                    
                 
 
        
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号