“ 本篇主要介绍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技术栈)查看更多文章!