kubernetes专辑之03定义清单YAML文件

简介: Kubernetes系列

k8s所有的配置文件以及资源的定义配置文件都是基于YAML格式的,所以熟悉并掌握YAML是必要的。先说说YAML常用的校验工具,然后在细说YAML的基本语法。

yaml工具

pip3 install pyyaml
python3 -c 'import yaml, sys; yaml.safe_load(sys.stdin)' < cfg.yaml

image-20200725210917109

  • 获取yaml的值的工具 shyaml
cat yapi-deployment.yml | shyaml get-value metadata.namespace
kube-ops
# 更多使用帮助请参考github上的文档

image-20200725222351846

YAML的设计目标

使用 YAML 文件的优点:

  1. YAML 文件可读性较高,易于实现和使用。
  2. 可在现有的所有编程语言之间轻松移植。
  3. 与敏捷语言的原生数据结构相匹配。
  4. YAML 文件具有一致模型,支持通用工具。
  5. YAML 文件支持 One-pass 处理。
  6. 使用方便,因此您无需再将所有的参数添加到命令行中。
  7. 易于维护 – 可以将 YAML 文件添加到源控件中以跟踪更改。
  8. 灵活便捷 – 可以使用 YAML 创建更加复杂的结构(相对于使用命令行可以创建的结构)

Yaml基础语法与技巧

  • 开始符号: ---用于表示开始的符号,在一个文件中包含多个YAML设定的时候使用非常常见。
  • 结束符号:用于表示yaml文件结束
  • 注释:YAML中使用#表示注释
apiVersion: v1 # #后面是注释的部分
  • 字符支持:YAML使用 Unicode 编码作为字符标准编码,可以使用UTF-8、UTF-16、UTF-32字符集
date: 2020-07-26
info:
  - name: "云原生生态圈"
tags:
  - num: 1
  - descript: "writing somthing here" 
  • 缩进:YAML中缩进是非常重要的规范,不支持Tab,支持空格,没有严格要求空格个数,但是需要确保同一层次的左侧对齐,下图就是一个错误的例子,缩进不规范

image-20200725221333627

  • 单行注释:单行注释使用#进行标记,可以在单行的任何位置开始注释的内容
  • 多行注释:不提供特殊的多行注释,使用多行行首的单行注释#实现多行注释的需求
info:
# 下面是两个空格,然后一个短横线
  - name: Marionxue
  • 基本数据类型:支持整型浮点型时间戳类型Null等基本数据类型
 integer: 12345     # 整数标准形式
 octal: 0o34        # 八进制表示,第二个是字母 o
 hex: 0xFF          # 十六进制表示

 float: 1.23e+3     # 浮点数
 fixed: 13.67       # 固定小数
 minmin: -.inf      # 表示负无穷
 notNumber: .NaN    # 无效数字

 null:              # 空值
 boolean: [true, false] # 布尔值
 string: '12345'    # 字符串

 date: 2015-08-23   # 日期
 datetime: 2015-08-23T02:02:00.1z  # 日期时间
 iso8601: 2015-08-23t21:59:43.10-05:00  # iso8601 日期格式
 spaced: 2015-08-23 21:59:43.10 -5      # ?
  • 组合数据类型:支持键/值方式和列表类型,并可进行嵌套组合
  • 键/值方式:使用冒号:进行分隔,也可使用{}结合逗号进行表达
  • 列表类型:使用横线-进行分隔,也可使用[]结合逗号进行表达
--- # start
- [dog, cat, docker] #list
- [apache, tomcat]
- site: {devopsman:www.devopsman.cn, kube: www.kubemaster.top}  # key/value list
  • 单引号与双引号:字符串类型可以不使用单引号和双引号,使用单引号和双引号与不使用的时候在特殊字符及其转义的时候有些细微的区别,可用倒斜线(\)进行特殊字符转义,但最终都表示为一行。
  • 区块的字串用缩排和修饰词(非必要)来和其他资料分隔,有新行保留(使用符号|)或新行折叠(使用符号>)两种方式,一般用在较长的描绘性说明中

    • |表示保留区块中的回车换行
    • >表示将区块中的回车换行替换为空行,最终连成一行
- describle: |
        Hi,all:
            my name is xxx.
- code: > # 注意: 区块中的换行会替换成空格
        fmt.Println("姓名: %s",
         name)
  • 强制类型转换:可以使用!!用于强制类型转换
---
account-limiter:
  account-blacklist:
    - 1
    - 2
    - 3
---
account-limiter:
  account-blackset: !!set {1, 2, 3} # 强制转换为set
...

# 以下为内置的类型
!!int               # 整数类型
!!float             # 浮点类型
!!bool              # 布尔类型
!!str               # 字符串类型
!!binary            # 也是字符串类型
!!timestamp         # 日期时间类型
!!null              # 空值
!!set               # 集合
!!omap, !!pairs     # 键值列表或对象列表
!!seq               # 序列,也是列表
!!map               # 键值表

# example
isString: !!str 2020-07-26     # 强调是字符串不是日期数据
picture: !!binary |            # Base64  图片
R0lGODlhDAAMAIQAAP//9/X
17unp5WZmZgAAAOfn515eXv
Pz7Y6OjuDg4J+fn5OTk6enp
56enmleECcgggoBADs=
  • 重复性内容:可以使用锚点标记&和应用标记*结合使用可以处理重复性的内容
 ---
 tags:
   - yaml
   # Following node labeled SS
   - &SS "yaml tool"            # 定义要复制的数据
 desc:
   - *SS # 这里是数据复制目标
   - pyyaml
  • 保留字符:@和`为当前YAML规格的保留字符
☸️  k8sdev🔥 default  ~  🐳 👉 cat demo.yaml
---
tags:
  - yaml
  # Following node labeled SS
  - &SS "yaml tool"            # 定义要复制的数据
desc:
  - *SS # 这里是数据复制目标
  - pyyaml
☸️  k8sdev🔥 default  ~  🐳 👉 cat demo.yaml| shyaml get-value desc.0
yaml tool%                                                                                                                                                                                     ☸️  k8sdev🔥 default  ~  🐳 👉 cat demo.yaml| shyaml get-value desc.1
pyyaml%                                                                                                                                                                                        ☸️  k8sdev🔥 default  ~  🐳 👉 cat demo.yaml| shyaml get-value tags.1
yaml tool%

YAML的注意事项

  • 空白字符限制:在使用逗号及冒号时,后须接一个空白字符
  • YAML使用可打印的Unicode字符,可使用UTF-8或UTF-16
  • 使用空白字符(不能使用Tab)分层,同层元素左侧对齐
  • 单行注解由井字号( # )开始,可以出现在行中任何位置
  • 每个清单成员以单行表示,并用短杠+空白(- )起始
  • 每个杂凑表的成员用冒号+空白(: )分开键和值
  • 杂凑表的键值可以用问号 (?)起始,表示多个词汇组成的键值
  • 字串一般不使用引号,但必要的时候可以用引号框住
  • 使用双引号表示字串时,可用倒斜线(\)进行特殊字符转义
  • 区块的字串用缩排和修饰词(非必要)来和其他资料分隔,有新行保留(使用符号|)或新行折叠(使用符号>)两种方式
  • 在单一档案中,可用连续三个连字号(---)区分多个档案
  • 可选择性的连续三个点号(...)用来表示档案结尾(在流式传输时非常有用,不需要关闭流即可知道到达结尾处)
  • 重复的内容可使从参考标记星号 (*)复制到锚点标记(&)
  • 指定格式可以使用两个惊叹号 ( !! ),后面接上名称

YAML可以用来做什么

当数据能够容易的被读懂的时候,任何事情都会变得简单。
  • 配置文件configuration files
  • 日志文件log files
  • 进程间消息传递interprocess messaging
  • 跨语言数据共享cross-language data sharing
  • 对象持久性object persistence
  • 复杂数据结构debugging of complex data structures

YAML与 JSON 和 XML 的关系

  • XML 是许多领域的优先采用格式。XML 最初设计为与标准通用标记语言 (SGML) 向后兼容,后者旨在支持结构化文档。因此,XML 存在许多设计上的约束。
  • JSON 的设计理念是简单性和通用性,并且易于生成和解析。JSON 格式的可读性低,但是这种格式的数据每一种现代编程环境都可以轻松处理。
  • YAML 的设计目标是提升可读性,提供更加完善的信息模型。YAML 的生成和解析更加复杂,因此可以将其视为 JSON 的自然超集。每个 JSON 文件都是一个有效的 YAML 文件。

在需要额外功能的情况下,可以轻松地从 JSON 迁移到 YAML。YAML 是从 XML 衍生而来。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
2月前
|
JSON Kubernetes API
深入理解Kubernetes配置:编写高效的YAML文件
深入理解Kubernetes配置:编写高效的YAML文件
|
1月前
|
Kubernetes 应用服务中间件 nginx
k8s学习--YAML资源清单文件托管服务nginx
k8s学习--YAML资源清单文件托管服务nginx
k8s学习--YAML资源清单文件托管服务nginx
|
1月前
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
76 3
|
1月前
|
Kubernetes Linux 容器
1.xshell传不了文件输出0000如何解决.....2.k8s中metalLB文件内容
1.xshell传不了文件输出0000如何解决.....2.k8s中metalLB文件内容
|
1月前
|
Kubernetes Docker Perl
k8s常见故障--yaml文件检查没有问题 pod起不来(一直处于创建中)
k8s常见故障--yaml文件检查没有问题 pod起不来(一直处于创建中)
102 1
|
1月前
ingress相关yaml文件报错且相关资源一切正常解决方法
ingress相关yaml文件报错且相关资源一切正常解决方法
ingress相关yaml文件报错且相关资源一切正常解决方法
|
2月前
|
Kubernetes Docker Python
dockercompose与k8s的pod文件的爱恨情仇
dockercompose与k8s的pod文件的爱恨情仇
|
Kubernetes 应用服务中间件 数据格式
使用YAML创建一个 Kubernetes Depolyment
在之前的文章中,我们已经提到过如何使用Kubernetes去创建资源。到目前为止,我们一直仅仅通过命令行去执行,但是这里有一个更加简单有效的方式去创建资源:通过使用YAML创建一个配置文件。在这篇文章,我们将会关注YAML的工作方式以及如何使用YAML创建一个Kubernetes Pod,然后使用Kubernetes创建一个Depolyment。
2052 0
|
5月前
|
存储 运维 Serverless
函数计算产品使用问题之在YAML文件中配置了环境变量,但在PHP代码中无法读取到这些环境变量,是什么原因
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
4月前
|
运维 Kubernetes Serverless
Serverless 应用引擎使用问题之s.yaml文件中如何使用外部环境变量
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
下一篇
无影云桌面