本篇主要介绍k8s的yaml文件主要构成,以顶层的5个元素为例,为后面自己写yaml资源文件做准备,使用kubectl explain了解每个元素如何使用”

apiVersion: API版本(核心群组版本)。

kind: 对象(objects)系统中的永久资源,列表(list)一个或多个资源类别的集合,简单类别(simple)包含作用在对象上的特殊行为和非持久实体。

metadata:元数据,标识API对象。API对象至少含有3个元数据:namespace,name,uid。

spec:期望状态,disired state,最重要的字段,用kubectl explain 查看二级或者三级字段如何使用。API对象通过spec去设置配置;用户通过配置系统的理想状态来改变系统 , 所有的操作都是声明(Declarative)的而不是命令式(Imperative)的 ;声明式操作在分布式系统中的好处是稳定,不怕丢操作或运行多次 。

    replicas:(副本数)

    containers:(必选字段)

status:实际状态,(当前状态 ,current state,只读的,本字段由kubernetes集群维护,用户不能删除或定义),对象部署后将当前的状态更新到status中。Pod的status信息主要包括conditions、phase、podIP、startTime等,其中phase描述对象所处的生命周期阶段、condition表示条件,由条件类型和状态值组成。

一个简单的nginx的Deployment资源定义:


apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
  namespace: nginx-example
 labels:
   apps: nginx
spec:
 replicas: 3
 selector:
  matchLabels:
   app: nginx
 template:
  metadata:
labels:
  app: nginx
  spec:
     containers:
     - name: nginx
        image: nginx:1.7.9
      ports:
      - containerPort: 80
        resources:
          limits:
            memory: "200Mi"
          requests:
           memory: "100Mi"
status: {}

如果您喜欢这篇文章,可扫描下方二维码,关注公众号(SRE技术栈)查看更多文章!

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐