Kubernetes的YAML字段解析

Posted Yuan_sr

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Kubernetes的YAML字段解析相关的知识,希望对你有一定的参考价值。

基本语法

  • 缩进时不允许使用Tab键,只允许使用空格
  • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
  • 标识注释,从这个字符一直到行尾,都会被解释器忽略

    ## 必须存在的属性

参数名字段类型说明
versionStringK8s API的版本,目前基本都为v1,可以使用kubectl api-version命令查看
kindString定义的资源类型和角色:比如:Pod
metadataObject元数据对象,福鼎值就写metadata
metadata.nameString元数据对象名字,自定义
metadata.namespaceString元数据命名空间,自定义
SpecObject详细定义对象,固定值为Spec
spec.containers[]listSpec对象的容器列表定义,是个列表
spec.containers[].nameString容器的名字
spec.containers[].imageString要用到的镜像名称

可选参数

spec.containers[].imagePullPolicyString定义镜像拉取策略,有Always、Never、IfNotPresent三个值可选,Always表示每次都尝试重新拉取镜像;Never便是仅使用本地有的镜像;IfNotPresent表示本地有就用本地的,没有的话在线拉取镜像,如果没有设置则默认值为Always
spec.containers[].command[]List指定容器启动命令,因为是数组可以指定多个,不指定则使用镜像打包时使用的启动命令。
spec.containers[].args[]List指定容器启动命令参数,因为是数组,可以指定多个
spec.containersp[].workingDirString指定容器的工作目录
spec.containers[].volumeMounts[]String指定容器内部的存储卷配置
spec.containers[].volumeMounts[].nameString指定可以被容器挂载的存储卷的名称
spec.containers[].volumeMounts[].mountPathString指定可以被容器挂载的存储卷的路径
spec.containers[].volumeMounts[].readOnlyString设置存储卷的读写模式,true或者false默认为读写模式
spec.containers[].ports[]List指定容器需要用到的端口列表
spec.containers[].ports[].nameString指定端口名称
spec.containers[].ports[].containerPortString指定容器需要监听的端口号
spec.containers[].ports[].hostPortString指定容器所在主机需要监听的端口号,默认跟上面containerPort相同,注意,设置了hostPort同一台主机无法启动该容器的相同副本(因为主机的端口号不能相同,这样会冲突)
spec.containers[].ports[].ProtocolString指定端口协议,支持TCP和UDP,默认为TCP
spec.containers[].envList指定容器运行前需要设置的环境变量
spec.restartPolicyString定义Pod的重启策略,可选值为Always、OnFailure,默认为Always;Always表示Pod一旦终止运行,则无论容器是如何终止的,kubelet服务都将重启它;OnFailure表示只有Pod以非零退出码终止时,kubelet才会重启该容器,如果容器正常结束,则kubelet将不会重启它;Never表示Pod终止后,kubelet将退出码报告给Master,不会重启该Pod
spec.nodeSelectorObject定义Node的Label过滤标签,以key:value格式指定
spec.imagePullSecretsObject定义pull镜像时使用secret名称,以name:secretkey格式指定
spec.hostNetworkBoolean定义是否使用主机网络模式,默认为false,设置true表示使用宿主机网络,不适用docker网桥,同时设置了true将无法在同一台宿主机上启动第二个副本

以上是关于Kubernetes的YAML字段解析的主要内容,如果未能解决你的问题,请参考以下文章

k8s学习-文档&概念

k8s学习-文档&概念

深度解析|基于 eBPF 的 Kubernetes 一站式可观测性系统

Kubernetes Scheduler全解析

Kubernetes_10_Scheduler全解析

四kubernetes集群YAML文件