容器编排技术 -- 了解Kubernetes对象

  • 1 了解Kubernetes对象

    • 1.1 对象(Object)规范和状态
    • 1.2 描述Kubernetes对象
    • 1.3 必填字段
  • 2 下一步?

了解Kubernetes对象

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和当前状态之间差异来调整,这种情况下,将会开始替代实例。

有关object spec、status和metadata更多信息,请参考“Kubernetes API Conventions”。

描述Kubernetes对象

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

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

nginx-deployment.yaml 
apiVersion: apps/v1beta1
kind: Deployment
metadata:name: nginx-deployment
spec:replicas: 3template:metadata:labels:app: nginxspec:containers:- name: nginximage: nginx:1.7.9ports:- containerPort: 80

使用上述.yaml文件创建Deployment,是通过在kubectl中使用kubectl create命令来实现。将该.yaml文件作为参数传递。如下例子:

$ kubectl create -f docs/user-guide/nginx-deployment.yaml --record

其输出与此类似:

deployment "nginx-deployment" created

必填字段

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

  • apiVersion - 创建对象的Kubernetes API 版本
  • kind - 要创建什么样的对象?
  • metadata- 具有唯一标示对象的数据,包括 name(字符串)、UID和Namespace(可选项)

还需要提供对象Spec字段,对象Spec的精确格式(对于每个Kubernetes 对象都是不同的),以及容器内嵌套的特定于该对象的字段。Kubernetes API reference可以查找所有可创建Kubernetes对象的Spec格式。

下一步?

  • 了解最重要的Kubernetes对象,如Pod

容器编排技术 -- 了解Kubernetes对象相关推荐

  1. 容器编排技术 -- 创建Kubernetes集群

    容器编排技术 -- 创建Kubernetes集群 Kubernetes可以在多种平台运行,从笔记本电脑,到云服务商的虚拟机,再到机架上的裸机服务器.要创建一个Kubernetes集群,根据不同场景需要 ...

  2. 容器编排技术 -- Kubernetes Replica Sets

    容器编排技术 -- Kubernetes Replica Sets 1 如何使用ReplicaSet 2 何时使用ReplicaSet 3 示例 4 ReplicaSet as an Horizont ...

  3. 容器编排技术 -- Kubernetes Nodes

    容器编排技术 -- Kubernetes Nodes 1 Node是什么? 2 Node Status 2.1 Addresses 2.2 Phase 2.3 Condition 2.4 Capaci ...

  4. 容器编排技术 -- Kubernetes kubectl scale 命令详解

    容器编排技术 -- Kubernetes kubectl scale 命令详解 1 kubectl scale 2 语法 3 示例 4 Flags kubectl scale 扩容或缩容 Deploy ...

  5. 容器编排技术 -- Kubernetes kubectl get 命令详解

    容器编排技术 -- Kubernetes kubectl get 命令详解 1 kubectl get 2 语法 3 示例 4 Flags kubectl get 获取列出一个或多个资源的信息. 可以 ...

  6. 容器编排技术 -- Kubernetes kubectl 命令表

    容器编排技术 -- Kubernetes kubectl 命令表 kubectl命令列表 kubectl run(创建容器镜像) kubectl expose(将资源暴露为新的 Service) ku ...

  7. 容器编排技术 -- Kubernetes kubectl create 命令详解

    容器编排技术 -- Kubernetes kubectl create 命令详解 1 kubectl create 2 语法 3 示例 4 Flags kubectl create 通过配置文件名或s ...

  8. 容器编排技术 -- Kubernetes kubectl run 命令详解

    容器编排技术 -- Kubernetes kubectl run 命令详解 1 kubectl run 2 语法: 3 示例: 4 其它详细说明 kubectl run 创建并运行一个或多个容器镜像. ...

  9. 容器编排技术 -- Kubernetes JSONpath Support

    容器编排技术 -- Kubernetes JSONpath Support JSONPath模板是由{}大括号括起来的JSONPath表达式组成.除了原始的JSONPath语法之外,我们还添加了三个函 ...

最新文章

  1. ssh(Struts+spring+Hibernate)三大框架整合-简述
  2. [异能程序猿]第一章 酒后事发(第一更)
  3. java arraylist 函数_使用Java-8中的函数ArrayList
  4. 本地化中文示例代码需求调查
  5. Arduino--超声波
  6. 如何在ubuntu下安装detectron2_如何在 Debian/Ubuntu 上手动安装安全更新?
  7. 多重循环控制之打印金字塔
  8. 字符串系列之最长回文子串
  9. java settime_Java日历setTime()方法及示例
  10. 实战演练!CISCO交换机端口安全一点通 (
  11. 巧用Delegate在Silverlight多个页面、控件中传递回调方法
  12. 关于python开发CRM系统
  13. choices参数 MTV与MVC ajax contentType 序列化组件 自定义分页器...
  14. 打开Lampix推出的台灯,即可在任何平面实现AR交互
  15. 《JSP实用教程(第2版)/耿祥义》错误之import属性导入多个包
  16. 基于python实现全网视频解析--javaWeb篇
  17. html取消父元素样式,CSS以防止子元素继承父样式
  18. 张涵诚:龙头企业应承担起产业数据生态构建的重任
  19. PCL笔记二:PCD解析;PCD读取;PCD与XYZ转换;
  20. QQ空间说说刷赞网页版开放公测

热门文章

  1. 可编辑的表格:jQuery+PHP实现实时编辑表格字段内容
  2. 人工智障学习笔记——梯度下降(1)基础变种
  3. ubuntu14.04+ceres安裝(亲测)
  4. CVPR2020十个顶级开源数据集
  5. Leetcode算法题(C语言)15--字符串中的第一个唯一字符
  6. 《剑指Offer》 不用加减乘除做加法
  7. Linux Vim显示行号方法详解
  8. SpringBoot—自定义线程池及并发定时任务模板
  9. 控件ListView相关属性 1217
  10. java演练 谁在哪里做什么 文字小游戏开发