#k8s常用资源

  • 工作负载:Pod,rs(ReplicasSet),deploy(Deployment),sts(StatefulSet),ds(DaemonSet),Job,Cronjob
  • 服务发现及负载均衡:svc(Service), ing(Ingress)
  • 配置与存储:Volume,pv( persistentvolumes ),pvc,cm(ConfigMap),Secret,DownwardAPI
  • 集群级: ns(Namespace),Node,Role,ClusterRole,RoleBinding,ClusterRoleBinding
  • 元数据: HPA,PodTemplate,LimitRange

#资源清单格式

apiVersion: group/apiversion  #API版本
kind: #资源类型
metadata: #元数据对象
name #如Pod名称
namespace #命名空间默认default
lables #标签
Spec: #详细对象
containers:#容器列表
- name #容器名称
image #镜像

获取 apiversion 版本信息 kubectl api-versions

获取字段设置帮助文档 kubectl explain pod kubectl explain pod.kind

主要资源配置清单:

apiVersion,kind,meadata,spec,status

apiVersion

  • 定义API版本,格式为groupname/version
  • 用kubectl api-versions获取当前k8s版本apiVersion信息

kind

  • Kind定义资源类型和角色,如Namespace、Pod、Service、Deployment

metadata

Metadata元数据对象,分为两大类:

  • 名称空间

    namespace:名称空间,默认default

    name:对象名称,名称空间的同一类型中必须唯一

    uid:唯一表示符

  • 常用可选字段

    labels:对象标签,键值数据,常被用作挑选条件

    annotation:作为挑选条件,作为labels的补充

    resourceVersion:当前对象的内部版本标识符

    generation:用于表示当前对象目标状态的代码

    creationTimestamp:当前对象创建日期的时间戳

    deletionTimestamp:当前对象删除日期的时间戳

status 当前状态,k8s集群维护,用户不能修改

spec 详细对象

 #spec常用资源类型
spec.containers.name:pod的名称,必须字段,名称唯一且创建后不可以被修改
spec.containers.image :镜像仓库路径/镜像名称(镜像标签)
spec.containers.image.imagePullPolicy :镜像下载策略
Always:总是下载
Never:从不下载
IfNotPresent:本地没有就下载,默认项
镜像标签是latest则总会是"Always",且一旦被创建不允许改变
spec.containers.ports:容器公开的端口列表
spec.containers.ports.containerPort:暴露的端口,是额外的信息,对端口是否暴露没影响
spec.containers.ports.hostPort:主机上公开端口
spec.containers.ports.protocol:端口协议TCP或UDP,默认TCP
spec.containers.ports.hostIP:指定要绑定的主机
spec.containers.command:运行程序,类似于docker中的entrypiont,命令不会运行在shell中
spec.containers.args:向docker镜像中传递参数,会替换docker镜像中cmd命令,引用变量使用
spec.containers.volumeMounts.mountPath:容器挂载存储卷的路径,路径不能包含':' 符号
spec.containers.volumeMounts.subPath:容器挂载的存储卷的 子路径
spec.containers.volumeMounts.readOnly:只读,默认为false
spec.containers.resources.limits:资源限制
spec.containers.resources.limits.cpu :CPU上限,可以短暂超过,容器也不会被停止
spec.containers.resources.limits.memory:内存上限
spec.containers.resources.requests:资源需求
spec.containers.resources.requests.cpu:CPU请求, 也是调度 CPU 资源的依据, 可以超过
spec.containers.resources.requests.memory:内存请求,可以超过;超过时容器可能在Node内存不足时清理
spec.containers.workingDir: 容器工作目录
spec.nodeSelector:指定Pod调度节点
spec.restartPolicy:容器重启策略三种 Always(退出就重启)、OnFailure(状态为错误时重启)、Never(不重启)
spec.imagePullSecrets pull镜像时使用cecrets名称

#实例 通过清单文件创建Pod

# pod-demo.yaml
apiVersion: v1
kind: Pod
metadata:
name: pod-demo
namespace: default
labels:
app: myapp
spec:
containers:
- name: test
image: busybox:latest
command:
- "/bin/sh"
- "-c"
- "echo -n 'running at ' && date +%F' '%T && sleep 20"
#创建pod
kubectl create -f pod-demo.yaml #查看pod
kubectl get pod pod-demo
kubectl get pod pod-demo -o wide
#查看详情
kubectl describe pod pod-demo
#查看logs
kubectl logs pod-demo -c test #删除
kubectl delete -f pod-demo.yaml #pod会反复重启,因为命令sleep 20结束

Blog地址 https://www.cnblogs.com/elvi/p/11755617.html

本文git地址 https://gitee.com/almi/k8s/tree/master/notes

1.k8s.资源清单的更多相关文章

  1. k8s资源清单定义入门

    1.资源分类 a.workload型资源:service.pod.deployment.ReplicaSet.StatefulSet.Job.Cronjob; b.服务发现及服务均衡资源型资源:Ser ...

  2. k8s资源清单基础

    资源清单介绍 创建资源的方法  apiserver仅接收JSON格式的资源定义  yaml格式提供配置清单 apiserver可自动把yaml转换成json格式数据 资源清单五个一级字段   1.ap ...

  3. 2.k8s资源清单

    一.常见资源对象 常见的资源对象:(包括但不仅限于) l  Workload: Pod,ReplicaSet,Deployment,StatefulSet,DaemonSet,Job,Cronjob ...

  4. k8s学习笔记之四:资源清单定义入门

    第一章.k8s中的资源 1.什么叫资源? k8s中所有的内容都抽象为资源, 资源实例化之后,叫做对象 2.在k8s中有哪些资源? 工作负载型资源(workload): Pod ReplicaSet D ...

  5. 四,k8s集群资源清单定义入门

    目录 资源对象 创建资源的方法 清单帮助命令 创建测试清单 资源的三种创建方式 资源对象 workload:Pod, ReplicaSet, Deployment, StatefulSet, Daem ...

  6. Kubernetes【K8S】(三):资源清单

    K8S中的资源 K8S中所有的内容都抽象为资源,资源实例化之后叫做对象.一般使用yaml格式的文件来创建符合我们预期的pod,这样的yaml文件我们一般成为资源清单. 名称空间级资源 工作负载型资源( ...

  7. 1.k8s概述、安装、名词解释、资源清单

    一.k8s概述 1.简介 Kubernetes是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes的目标是让部署容器化的应用简单并且高效(powerful),Kubernete ...

  8. k8s学习笔记之五:Pod资源清单spec字段常用字段及含义

    第一章.前言 在上一篇博客中,我们大致简述了一般情况下资源清单的格式,以及如何获得清单配置的命令帮助,下面我们再讲解下清单中spec字段中比较常见的字段及其含义 第二章.常用字段讲解 spec.con ...

  9. k8s学习-资源清单

    4.kubernetes使用 4.1.资源清单 api 文档.api 描述 4.1.2.说明 必须存在的属性 主要的对象 额外的参数项 例子 vim my-app.yml apiVersion: v1 ...

随机推荐

  1. python 查询Neo4j多节点的多层关系

    需求:查询出满足3人及3案有关系的集合 # -*- coding: utf-8 -*- from py2neo import Graph import psycopg2 # 二维数组查找 def fi ...

  2. Nginx 的全局和虚拟主机配置

    Httpd.conf nginx.conf my-heavy-innode-4G.cnf php.ini  用中文注释 # user:指定 Nginx Worker 进程运行用户和用户组,默认 nob ...

  3. Consider defining a bean of type 'org.springframework.web.client.RestTemplate' in your configuration

    https://www.cnblogs.com/EasonJim/p/7546136.html 错误如下: ERROR 31473 --- [ main] o.s.b.d.LoggingFailure ...

  4. Linux vim程序编辑器

    Tips: 在 vi 里面, [tab] 这个按钮所得到的结果与空格符所得到的结果是不一样的,特别强调一下! 一般模式 移动光标 30↓ 向下移动30行 40→ 向右移动40个字符 gg 移动到档案第 ...

  5. 使用node来搭建简单的后台业务

    现在作为一个前端开发人员,越来越多的技术需要学习,近几天学习了下node.js,在很多前端以及后端应用了该技术,现在记录下自己摸索的一些简单的知识记录下来. 我的博客都是直接分享应用方法,没有说明一些 ...

  6. 常用sql---表记录数和占用空间统计

    1.每张表的记录数和占用空间 select owner as 用户名, table_name as 表名, num_rows as 记录数, ROUND(t.NUM_ROWS * t.AVG_ROW_ ...

  7. Composer\Downloader\TransportException ... Failed to enable crypto,failed to open stream: operation failed

    failed to open stream: operation failed 错误详细信息: [Composer\Downloader\TransportException] The "h ...

  8. 【01】Python 环境变量、条件判断、循环、基本运算符

    1 环境变量 1.1 Windows下环境变量 系统变量Path中要加入Python安装路径: C:\xxxx\Python36;C:\xxxx\Python36\Scripts; 2 条件判断 2. ...

  9. Vuejs使用scoped(私有) style为v-html中标签添加CSS样式

    最近使用Vue框架的时候遇到一个问题,就是后台把数据写好了,而且写好的数据的某些内容是html格式的,使用Vue框架的v-html虽然可以很简单的就把数据转换成html的标签渲染在页面上,但是有些样式 ...

  10. Hybris commerce产品主数据的搜索API,批量返回若干主数据的值

    新建一个产品,identifier设置为i042416-1,创建之后立即能够在Backoffice里搜索出来: 等到Storefront的indexing做完之后,前台通过关键字i042416也能将这 ...