资源:对象

service pod deployment

workload:pod,ReplicaSet,Deployment,statefulset,DaemonSet,Job,Crontabjob,...

服务发现和负载均衡:service ,Ingress,....

配置与存储:Volumn存储卷 ,CSI存储接口

ConfigMap,Secret,

DownwardAPI

集群级资源:namespace,Node,Role,ClusterRole,RoleBinding,ClusterRoleBinding,

元数据型资源

HPA,PodTemplate,LimitRange

kubectl get pod myapp-84cd4b7f95-h47cj -o yaml

yml文件查看pod详细的配置清单

创建资源的方法:

apiserver仅接收JSON格式的资源定义;

yaml格式提供配置清单,apiserver可自动转为json格式,而后在提交

kubectl api-versions

大部分资源的配置清单:

apiVerison:group/version,

kind:资源类别

metadata:元数据

name

namespace

labels

annotations 资源注解

每个资源的引用PATH

/api/GROUP/VERSION/namespaces/NAMESPACE/TYPE/NAME

spec:规格 期望的状态 disired state

spec.containers

- name <string>

image <string>

imagePullPolicy <string>

Always,Never,IfNotPresent

总是去仓库下载 不下载 不存在就去下载,存在就直接使用

修改镜像中默认的运用:

kubectl explain pods.spec.containers

command ,args

https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell

标签labels

kubectl get pods --show-labels

key=value(小于63个字符)

key:字母,数字,”-_”

value:可以为空

kubectl get pods -l app --show-labels 找出含有app标签的pod

kubectl get pods -L app,run --show-labels -o wide 匹配字段查询

打标签

kubectl label –help

kubectl label pods pod-demo release=canary

类型   资源名     标签名=canary

kubectl get pods -l app --show-labels  查看是否打上标签

覆盖修改标签

kubectl label pods pod-demo release=stable –overwrite

kubectl get pods -l app,release --show-labels 既有app也有release标签

标签选择器

等值:=,==,!=

kubectl get pods -l release=stable  --show-labels

kubectl label pods nginx-7bb7cd8db5-7dn9r release=canary

kubectl get pods -l release

kubectl get pods -l release=canary

kubectl get pods -l release,app

kubectl get pods -l release=stable,app=myapp

kubectl get pods -l release!=canary --show-labels

集合关系:key in (values1,value2…), key not in (values1,value2…),key,!key

kubectl get pods -l "release in (canary,beta,alpha)" --show-labels

kubectl get pods -l "release notin (canary,beta,alpha)" --show-labels

许多资源支持内嵌字段定义其使用标签选择器:

matchLabels:直接给定键值,相当于=

matchExpressions:基于给定的表达式来定义使用标签选择器,{key:”KEY”,operator:”OPERATOR”,values:[VAL1,VAL2…]}大写字母表示替换

operator操作符:In ,NotIn values字段必须为非空列表

Exists,NotExists values字段必须为空列表

各种对象都能打标签,不仅限于pod,比如node

kubectl get nodes --show-labels

kubectl label nodes node02 disktype=ssd 对node02打标签

kubectl explain pods.spec

nodeSelector     <map[string]string> 节点标签选择器

kubectl label nodes node01 disktype=hd

vim pod-demo.yaml

containers:

nodeSelector:

disktype: hd

kubectl delete -f pod-demo.yaml

kubectl create -f pod-demo.yaml 再次创建会运行在node01上

kubectl describe pods pod-demo

nodeName   <string> 指定运行在哪个节点上

annotations:资源注解

与label不同的地方在于,它不能用于挑选资源对象,仅用于为对象提供”元数据”,

vim pod-demo.yaml

metadata:

annotations:

work in node02: "disk is ssd"

kubectl delete -f pod-demo.yaml

kubectl create -f pod-demo.yaml

kubectl describe pods pod-demo

Annotations:  work_in_node02: disk is ssd

status:当前状态,current state,本字段由kubernetes集群维护;用户不能定义

kubectl explain pods 查询pods怎么定义

kubectl explain pods.metadata 查询pods的metadata怎么定义

kubectl explain pods.spec

kubectl explain pods.spec.containers

kubectl explain pods.spec.containers.livenessProbe

例如:自定义一个pod资源

vim pod-demo.yaml

apiVersion: v1

kind: Pod

metadata:

name: pod-demo

namespace: default

labels:

app: myapp

tier: frontend

spec:

containers:

- name: myapp

image: ikubernetes/myapp:v1

ports:

- name: http

containerPort: 80

- name: https

containerPort: 443

- name: busybox

image: busybox:latest

imagePullPolicy: IfNotPresent

command:

- "/bin/sh"

- "-c"

- "sleep 3600"

注释:

spec:

containers:

- name: myapp

image: ikubernetes/myapp:v1

相当于 spec:{containers:['name:myapp'],image:"ikubernetes/myapp:v1"}

command:

- "/bin/sh"

- "-c"

- "sleep 3600"

相当于 command:["/bin/sh","-c","sleep 3600"]

kubectl create -f pod-demo.yaml    基于yaml清单文件创建pod资源

从文件加载创建资源

kubectl get pods 再查看一下创建的pod

kubectl describe pods pod-demo 查看创建的资源的描述信息

查看容器日志

kubectl logs pod-demo myapp

pod名  pod里面的容器名

进入容器

kubectl exec -it pod-demo -c myapp -- /bin/sh

输入和终端 pod名 -c指定容器名 --执行的命令

kubectl delete -f pod-demo.yaml 删除基于资源清单yaml文件定义的资源

k8s资源清单创建pod的更多相关文章

  1. Kubernetes中资源清单与Pod的生命周期(二)

    一.资源清单 1,定义: 在k8s中一般使用yaml格式的文件来创建符合我们预期的资源,这样的yaml被称为资源清单. 使用资源清单创建Pod: kubectl apply -f nginx.yaml ...

  2. 【04】Kubernets:资源清单(pod)

    写在前面的话 前面我们提到过,纯手敲 K8S 名称管理 K8S 服务只是作为我们了解 K8S 的一种方案,而我们最终管理 K8S 的方法还是通过接下来的资源清单的方式进行管理. 所以从本章节开始,将会 ...

  3. k8s资源清单定义入门

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

  4. k8s资源清单基础

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

  5. 2.k8s资源清单

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

  6. 1.k8s.资源清单

    #k8s常用资源 工作负载:Pod,rs(ReplicasSet),deploy(Deployment),sts(StatefulSet),ds(DaemonSet),Job,Cronjob 服务发现 ...

  7. kubernetes资源清单之pod

    什么是pod? Pod是一组一个或多个容器(例如Docker容器),具有共享的存储/网络,以及有关如何运行这些容器的规范. Pod的内容始终位于同一地点,并在同一时间安排,并在共享上下文中运行. Po ...

  8. 6、kubernetes资源清单之Pod控制器190714

    一.Pod控制器的类别 ReplicationController:早期唯一的控制器,已废弃 ReplicaSet:控制Pod满足用户期望副本:标签选择器选择由自己管理的Pod副本:Pod资源模板完成 ...

  9. 12.深入k8s:kubelet创建pod流程源码分析

    转载请声明出处哦~,本篇文章发布于luozhiyun的博客:https://www.luozhiyun.com 源码版本是1.19 在上一篇中,我们知道在kubelet中,工作核心就是围绕着整个syn ...

  10. k8s资源清单

    资源清单就是k8s当中用来定义pod的文件,语法格式遵循yaml语法,在yaml当中可以定义控制器类型,元数据,容器端口号等等等....,也可以针对于清单对pod进行删除等操作. 我们可以用kubec ...

随机推荐

  1. 如何在 CentOS 7 linux上安装和使用 FFmpeg

    SSH首选FinalShell 1.下载解压 wget http://www.ffmpeg.org/releases/ffmpeg-5.1.tar.gz tar -zxvf ffmpeg-5.1.ta ...

  2. SpringBoot - [07] Web入门

    题记部分 一.Web 入门   SpringBoot将传统Web开发的mvc.json.tomcat等框架整合,提供了spring-boot-starter-web组件,简化了Web应用配置.创建Sp ...

  3. Linux - centos6.6不使用ssh如何在服务器之间传输文件?

    根据上一篇的设定,如果升级openssh失败之后,又无法使用ssh,该怎么传输文件呢? 可以使用busybox进行文件传输,首先需要准备两台centos6.6服务器:ctos66-01和ctos66- ...

  4. python文件不显示cmd黑窗口,打包py,pyw文件为exe文件

    问题描述:编写的python文件为定时任务,需要长时间运行,但是打开的cmd黑色窗口看起来很不舒服,于是打包为exe文件,隐藏cmd黑色窗口 步骤:1.使用pip install pyinstalle ...

  5. 在 Mac 上解决 LM Studio 无法下载模型的问题(国内镜像替换教程)

    如果你在使用 LM Studio 时遇到类似 There was an error fetching results from Hugging Face 或 Model details error: ...

  6. 【Abaqus】*Solid Section定义复合材料

    *SOLID SECTION 介绍 *solid section 用来定义单元的材料属性,材料方向等信息: solid (continuum) elements infinite elements a ...

  7. Laravel11 从0开发 Swoole-Reverb 扩展包(一) - 扩展包开发

    前言 大家好呀,我是yangyang.好久没更新了,最近新项目在使用laravel11(截止目前发文,laravel12也发布了)做开发,自己也是利用有些空闲时间做些除开业务以外的深入学习,因此也就萌 ...

  8. Laravel11 从0开发 Swoole-Reverb 扩展包(四) - 触发一个广播事件到reverb服务之后是如何转发给前端订阅的呢(下)?

    前情提要 上一篇我们讲到了reverb服务的通信上下文和路由处理,路由实现了pusher关联的几种请求.那么这一篇我们主要来讲混响服务Server 混响 Server 负责基于 ReactPHP 的 ...

  9. 题解:CF2077B Finding OR Sum

    本文发布于博客园和洛谷,若您在其他平台阅读到此文,请前往博客园获得更好的阅读体验. 跳转链接:https://www.cnblogs.com/TianTianChaoFangDe/p/18771334 ...

  10. Golang 入门 : Go语言介绍

    简介 Go 语言又称 Golang,由 Google 公司于 2009 年发布,近几年伴随着云计算.微服务.分布式的发展而迅速崛起,跻身主流编程语言之列,和 Java 类似,它是一门静态的.强类型的. ...