1. 字典同级元素 缩进
  2. A:
  3. a
  4. b
  5. 列表同级元素 - 缩进
  6. A:
  7. - a
  8. - b
  9. --- 同一个文件 不同资源

image.png

YAML介绍

image.png

  1. 除了某些强制性的命令,如:kubectl run或者expose等,会隐式创建rc或者svc
  2. k8s还允许通过配置文件的方式来创建这些操作对象。
  3. 通常,使用配置文件的方式会比直接使用命令行更可取,
  4. 因为这些文件可以进行版本控制,而且文件的变化和内容也可以进行审核,
  5. 当使用及其复杂的配置来提供一个稳健、可靠和易维护的系统时,这些点就显得非常重要。
  6. 在声明定义配置文件的时候,
  7. 所有的配置文件都存储在YAML或者JSON格式的文件中并且遵循k8s的资源配置方式。
  8. kubectl可以创建、更新、删除和获得API操作对象,
  9. 当前apiVersionkindname会组成一个API Path以供kubectl来调用。
  10. YAML是专门用来写配置文件的语言,非常简洁和强大,
  11. 使用比json更方便。它实质上是一种通用的数据串行化格式。
  12. kubernetes中用来定义YAML文件创建Pod和创建Deployment等资源。

使用YAML做K8s资源定义的好处

  1. - 便捷性: 不必添加大量的参数到命令行中执行命令
  2. - 可维护性: YAML文件可以通过源头控制,跟踪每次操作
  3. - 灵活性: YAML可以创建比命令行更加复杂的结构

YAML语法规则

  1. - 大小写敏感
  2. - 使用缩进表示层级关系
  3. - 缩进时不允许使用Tab键,只允许使用空格
  4. - 缩进的空格数不重要,只要相同层级的元素左侧对齐即可
  5. - #表示注释,从这个字符一直到行尾,都会被解析器忽略
  6. 在同一个yaml配置文家内可以同时定义多个资源
  7. 必须带"---"

image.png

yaml结构类型

  1. k8s 中,只需要知道两种结构类型:
  2. - Lists
  3. - Maps

YAML Maps

  1. Map指的是字典,即一个Key:Value 的键值对信息。
  2. eg:
  3. ---
  4. apiVersion: v1
  5. kind: Pod
  6. ---"
  7. 为可选的分隔符 ,
  8. 当需要在一个文件中定义多个结构的时候需要使用。
  9. 上述内容表示有两个键apiVersion和kind,分别对应的值为v1和Pod。
  10. Maps的value既能够对应字符串也能够对应一个Maps
  11. eg:
  12. ---
  13. apiVersion: v1
  14. kind: Pod
  15. metadata:
  16. name: kube100-site
  17. labels:
  18. app: web
  19. 注:上述的YAML文件中,metadata这个KEY对应的值为一个Maps,
  20. 而嵌套的labels这个KEY的值又是一个Map。实际使用中可视情况进行多层嵌套。
  21. YAML处理器根据行缩进来知道内容之间的关联。上述例子中,
  22. 使用两个空格作为缩进,但空格的数据量并不重要,只是至少要求一个空格并且所有缩进保持一致的空格数 。
  23. 例如,name和labels是相同缩进级别,因此YAML处理器知道他们属于同一map;
  24. 它知道app是lables的值因为app的缩进更大。

YAML Lists

  1. List即列表,就是数组。
  2. eg
  3. args:
  4. - beijing
  5. - shanghai
  6. - shenzhen
  7. - guangzhou
  8. 可以指定任何数量的项在列表中,每个项的定义以连字符(-)开头,并且与父元素之间存在缩进。
  9. JSON格式中,表示如下:
  10. {
  11. "args": ["beijing", "shanghai", "shenzhen", "guangzhou"]
  12. }
  13. 当然Lists的子项也可以是MapsMaps的子项也可以是List
  14. eg
  15. ---
  16. apiVersion: v1
  17. kind: Pod
  18. metadata:
  19. name: kube100-site
  20. labels:
  21. app: web
  22. spec:
  23. containers:
  24. - name: front-end
  25. image: nginx
  26. ports:
  27. - containerPort: 80
  28. - name: flaskapp-demo
  29. image: jcdemo/flaskapp
  30. ports: 8080
  31. 如上述文件所示,定义一个containersList对象,每个子项都由nameimageports组成,
  32. 每个ports都有一个KEYcontainerPortMap组成,转成JSON格式文件:
  33. {
  34. "apiVersion": "v1",
  35. "kind": "Pod",
  36. "metadata": {
  37. "name": "kube100-site",
  38. "labels": {
  39. "app": "web"
  40. },
  41. },
  42. "spec": {
  43. "containers": [{
  44. "name": "front-end",
  45. "image": "nginx",
  46. "ports": [{
  47. "containerPort": "80"
  48. }]
  49. }, {
  50. "name": "flaskapp-demo",
  51. "image": "jcdemo/flaskapp",
  52. "ports": [{
  53. "containerPort": "5000"
  54. }]
  55. }]
  56. }
  57. }
  58. k8spod中运行容器,一个包含简单的Hello World容器的pod可以通过YAML文件这样来定义:
  59. apiVersion: v1
  60. kind: Pod deployment service
  61. metadata:
  62. name: hello-world
  63. spec:
  64. restartPolicy: Never
  65. containers:
  66. - name: hello
  67. image: "ubuntu:14.04"
  68. command: ["/bin/echo","hello","world"]
  69. 创建的pod名为metadata.name的值:hello-world,该名称必须是唯一的。
  70. spec的内容为该pod中,各个容器的声明
  71. restartPolicyNever 表示启动后运行一次就终止这个pod
  72. containers[0].name 为容器的名字。
  73. containers[0].image 为该启动该容器的镜像。
  74. containers[0].command 相当于Dockerfile中定义的Entrypoint
  75. 可以通过下面的方式来声明cmd的参数:
  76. command: ["/bin/echo"]
  77. args: ["hello","world"]