K8S对象


参考文档:http://docs.kubernetes.org.cn/232.html

一、基本概念

Kubernetes对象是Kubernetes系统中的持久实体。Kubernetes使用这些实体来表示集群的状态。具体来说,他们可以描述:

容器化应用正在运行(以及在哪些节点上)
这些应用可用的资源
关于这些应用如何运行的策略,如重新策略,升级和容错
Kubernetes对象是“record of intent”,一旦创建了对象,Kubernetes系统会确保对象存在。通过创建对象,可以有效地告诉Kubernetes系统你希望集群的工作负载是什么样的。

要使用Kubernetes对象(无论是创建,修改还是删除),都需要使用Kubernetes API。例如,当使用kubectl命令管理工具时,CLI会为提供Kubernetes API调用。你也可以直接在自己的程序中使用Kubernetes API,Kubernetes提供一个golang客户端库 (其他语言库正在开发中-如Python)。

二、对象(Object)规范和状态

每个Kubernetes对象都包含两个嵌套对象字段,用于管理Object的配置:Object Spec和Object Status。Spec描述了对象所需的状态 - 希望Object具有的特性,Status描述了对象的实际状态,并由Kubernetes系统提供和更新。

例如,通过Kubernetes Deployment 来表示在集群上运行的应用的对象。创建Deployment时,可以设置Deployment Spec,来指定要运行应用的三个副本。Kubernetes系统将读取Deployment Spec,并启动你想要的三个应用实例 - 来更新状态以符合之前设置的Spec。如果这些实例中有任何一个失败(状态更改),Kuberentes系统将响应Spec和当前状态之间差异来调整,这种情况下,将会开始替代实例。

三、描述Kubernetes对象

在Kubernetes中创建对象时,必须提供描述其所需Status的对象Spec,以及关于对象(如name)的一些基本信息。当使用Kubernetes API创建对象(直接或通过kubectl)时,该API请求必须将该信息作为JSON包含在请求body中。通常,可以将信息提供给kubectl .yaml文件,在进行API请求时,kubectl将信息转换为JSON。

以下示例是一个.yaml文件,显示Kubernetes Deployment所需的字段和对象Spec:

apiVersion: v1      #namespace版本
kind: Namespace     #对象类型
metadata:           #元数据
  name: deploy-namespace  #namespace名称
---
apiVersion: apps/v1beta1   #deployment版本
kind: Deployment		#对象类型
metadata:				#元数据
  name: nginx			#deployment名字
  namespace: deploy-namespace#deployment所在名字空间
spec:					#期望
  replicas: 3			#副本数
  template:				#Pod Template 是关于 Pod 的定义,但是被包含在其他的 Kubernetes 对象中(例如 Deployment、StatefulSet、DaemonSet 等控制器)。控制器通过 Pod Template 信息来创建 Pod。
    metadata:			#元数据
      labels:			#标签
        app: nginx-v4	#设定标签app=nginx-v4
    spec:				#期望
      containers:		#容器
      - name: nginx		#容器名
        image: hlqlinux/hlq-test:nginx-v4#容器镜像
        ports:
        - containerPort: 80 #端口

创建deployment

[root@iZbp16ke9g4qwtz7gw25fnZ ~]# kubectl create -f deployment.yaml 
namespace/deploy-namespace created
deployment.apps/nginx created

验证

[root@iZbp16ke9g4qwtz7gw25fnZ ~]# kubectl get pod -n=deploy-namespace -owide
NAME                    READY   STATUS    RESTARTS   AGE     IP            NODE                      NOMINATED NODE   READINESS GATES
nginx-8cbb7b9cd-c492p   1/1     Running   0          2m16s   10.244.5.21   izbp1hmezfxg8nhvitxlsyz   <none>           <none>
nginx-8cbb7b9cd-ksnwx   1/1     Running   0          2m16s   10.244.5.22   izbp1hmezfxg8nhvitxlsyz   <none>           <none>
nginx-8cbb7b9cd-sz8sn   1/1     Running   0          2m16s   10.244.5.20   izbp1hmezfxg8nhvitxlsyz   <none>           <none>
[root@iZbp16ke9g4qwtz7gw25fnZ ~]# curl 10.244.5.21:80
this is hlqlinux's test-nginx

四、必填字段

对于要创建的Kubernetes对象的yaml文件,需要为以下字段设置值:

apiVersion - 创建对象的Kubernetes API 版本
kind - 要创建什么样的对象?
metadata- 具有唯一标示对象的数据,包括 name(字符串)、UID和Namespace(可选项)
还需要提供对象Spec字段,对象Spec的精确格式(对于每个Kubernetes 对象都是不同的),以及容器内嵌套的特定于该对象的字段。Kubernetes API reference可以查找所有可创建Kubernetes对象的Spec格式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值