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搭建和管理企业级网站应用
相关文章
|
3月前
|
Kubernetes 应用服务中间件 nginx
k8s学习--YAML资源清单文件托管服务nginx
k8s学习--YAML资源清单文件托管服务nginx
k8s学习--YAML资源清单文件托管服务nginx
|
3月前
|
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容器编排
113 3
|
3月前
|
Kubernetes Linux 容器
1.xshell传不了文件输出0000如何解决.....2.k8s中metalLB文件内容
1.xshell传不了文件输出0000如何解决.....2.k8s中metalLB文件内容
|
3月前
|
Kubernetes Docker Perl
k8s常见故障--yaml文件检查没有问题 pod起不来(一直处于创建中)
k8s常见故障--yaml文件检查没有问题 pod起不来(一直处于创建中)
141 1
|
3月前
ingress相关yaml文件报错且相关资源一切正常解决方法
ingress相关yaml文件报错且相关资源一切正常解决方法
ingress相关yaml文件报错且相关资源一切正常解决方法
|
13天前
|
缓存 容灾 网络协议
ACK One多集群网关:实现高效容灾方案
ACK One多集群网关可以帮助您快速构建同城跨AZ多活容灾系统、混合云同城跨AZ多活容灾系统,以及异地容灾系统。
|
23天前
|
Kubernetes Ubuntu 网络安全
ubuntu使用kubeadm搭建k8s集群
通过以上步骤,您可以在 Ubuntu 系统上使用 kubeadm 成功搭建一个 Kubernetes 集群。本文详细介绍了从环境准备、安装 Kubernetes 组件、初始化集群到管理和使用集群的完整过程,希望对您有所帮助。在实际应用中,您可以根据具体需求调整配置,进一步优化集群性能和安全性。
91 12
|
26天前
|
Prometheus Kubernetes 监控
OpenAI故障复盘 - 阿里云容器服务与可观测产品如何保障大规模K8s集群稳定性
聚焦近日OpenAI的大规模K8s集群故障,介绍阿里云容器服务与可观测团队在大规模K8s场景下我们的建设与沉淀。以及分享对类似故障问题的应对方案:包括在K8s和Prometheus的高可用架构设计方面、事前事后的稳定性保障体系方面。
|
28天前
|
Kubernetes 网络协议 应用服务中间件
Kubernetes Ingress:灵活的集群外部网络访问的利器
《Kubernetes Ingress:集群外部访问的利器-打造灵活的集群网络》介绍了如何通过Ingress实现Kubernetes集群的外部访问。前提条件是已拥有Kubernetes集群并安装了kubectl工具。文章详细讲解了Ingress的基本组成(Ingress Controller和资源对象),选择合适的版本,以及具体的安装步骤,如下载配置文件、部署Nginx Ingress Controller等。此外,还提供了常见问题的解决方案,例如镜像下载失败的应对措施。最后,通过部署示例应用展示了Ingress的实际使用方法。
61 2
|
1月前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。