Kubernetes的Group、Version、Resource学习小记

  1. 在kubernetes环境被实例化的资源即资源对象(ResourceObject);

  2. 资源被分为持久性(Persistent Entity)和非持久性(Ephemeral Entity),持久性如deployment,创建后会在etcd保存,非持久性如pod;

  • 资源的源码:

type APIResource struct {

Name string json:"name" protobuf:"bytes,1,opt,name=name"

SingularName string json:"singularName" protobuf:"bytes,6,opt,name=singularName"

Namespaced bool json:"namespaced" protobuf:"varint,2,opt,name=namespaced"

Group string json:"group,omitempty" protobuf:"bytes,8,opt,name=group"

Version string json:"version,omitempty" protobuf:"bytes,9,opt,name=version"

Kind string json:"kind" protobuf:"bytes,3,opt,name=kind"

Verbs Verbs json:"verbs" protobuf:"bytes,4,opt,name=verbs"

ShortNames []string json:"shortNames,omitempty" protobuf:"bytes,5,rep,name=shortNames"

Categories []string json:"categories,omitempty" protobuf:"bytes,7,rep,name=categories"

StorageVersionHash string json:"storageVersionHash,omitempty" protobuf:"bytes,10,opt,name=storageVersionHash"

}

  • kubernetes为资源准备了8种操作:create、delete、deletecollection、get、list、patch、update、watch,每一种资源都支持其中的一部分,这在每个资源的API文档中可以看到;

  • 资源支持以命名空间(namespace)进行隔离;

  • 资源对象描述文件在日常操作中频繁用到,一共由五部分组成:apiVersion、kind、metadata、spec、status,下图是官方的deployment描述文件,用于创建3个nginx pod,对着红框和文字就了解每个部分的作用了:

在这里插入图片描述

  • 上图并没有status,该部分是用来反应当前资源对象状态的,体现在资源的数据结构中,如下所示:

type Deployment struct {

metav1.TypeMeta json:",inline"

metav1.ObjectMeta json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"

Spec DeploymentSpec json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"

Status DeploymentStatus json:"status,omitempty" protobuf:"bytes,3,opt,name=status"

}

官方文档速查

  • 在实际学习和开发中,对指定资源做增删改查操作时,官方文档是我们最可靠的依赖,地址:https://kubernetes.io/docs/reference/kubernetes-api/

  • 打开deployment的文档,如下图:

在这里插入图片描述

  • 另外还有API文档也是必不可少的,遗憾的是目前没有找到1.20的API在线文档,最新的是1.19版本,地址:https://v1-19.docs.kubernetes.io/docs/reference/generated/kubernetes-api/v1.19/

  • 下图是deployment的api接口文档,可见示例、path、请求响应参数都有详细的说明,对咱们的学习和开发提供了强有力的支持:

在这里插入图片描述

APIResources数据结构

  • APIResource是个常用的数据结构了,可以用来描述资源,例如resource_quota_controller_test.go中有对其的使用:

func TestDiscoverySync(t *testing.T) {

serverResources := []*metav1.APIResourceList{

{

GroupVersion: “v1”,

APIResources: []metav1.APIResource{

{Name: “pods”, Namespaced: true, Kind: “Pod”, Verbs: metav1.Verbs{“create”, “delete”, “list”, “watch”}},

},

},

}

unsyncableServerResources := []*metav1.APIResourceList{

{

GroupVersion: “v1”,

APIResources: []metav1.APIResource{

{Name: “pods”, Namespaced: true, Kind: “Pod”, Verbs: metav1.Verbs{“create”, “delete”, “list”, “watch”}},

{Name: “secrets”, Namespaced: true, Kind: “Secret”, Verbs: metav1.Verbs{“create”, “delete”, “list”, “watch”}},

},

},

}

实际操作

  • 聊了这么久理论,接下来咱们在kubernetes环境执行一些和资源有关的操作;

  • 查看所有资源kubectl api-resources -o wide,可见当前环境的所有资源,及其相关属性:

[root@kubebuilder 07]# kubectl api-resources -o wide

NAME SHORTNAMES APIVERSION NAMESPACED KIND VERBS

bindings v1 true Binding [create]

componentstatuses cs v1 false ComponentStatus [get list]

configmaps cm v1 true ConfigMap [create delete deletecollection get list patch update watch]

endpoints ep v1 true Endpoints [create delete deletecollection get list patch update watch]

events ev v1 true Event [create delete deletecollection get list patch update watch]

limitranges limits v1 true LimitRange [create delete deletecollection get list patch update watch]

namespaces ns v1 false Namespace [create delete get list patch update watch]

  • 只看apps这个group下面的资源kubectl api-resources --api-group apps -o wide:

[root@kubebuilder 07]# kubectl api-resources --api-group apps -o wide

NAME SHORTNAMES APIVERSION NAMESPACED KIND VERBS

controllerrevisions apps/v1 true ControllerRevision [create delete deletecollection get list patch update watch]

daemonsets ds apps/v1 true DaemonSet [create delete deletecollection get list patch update watch]

deployments deploy apps/v1 true Deployment [create delete deletecollection get list patch update watch]

replicasets rs apps/v1 true ReplicaSet [create delete deletecollection get list patch update watch]

statefulsets sts apps/v1 true StatefulSet [create delete deletecollection get list patch update watch]

  • 查看指定资源的详情kubectl explain configmap:

[root@kubebuilder 07]# kubectl explain configmap

KIND: ConfigMap

VERSION: v1

DESCRIPTION:

ConfigMap holds configuration data for pods to consume.

FIELDS:

apiVersion

APIVersion defines the versioned schema of this representation of an

object. Servers should convert recognized schemas to the latest internal

value, and may reject unrecognized values. More info:

https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources

binaryData <map[string]string>

  • 查看所有Group和Version的命令kubectl api-versions

[root@kubebuilder 07]# kubectl api-versions

admissionregistration.k8s.io/v1

admissionregistration.k8s.io/v1beta1

apiextensions.k8s.io/v1

apiextensions.k8s.io/v1beta1

apiregistration.k8s.io/v1

apiregistration.k8s.io/v1beta1

apps/v1

authentication.k8s.io/v1

authentication.k8s.io/v1beta1

authorization.k8s.io/v1

authorization.k8s.io/v1beta1

autoscaling/v1

autoscaling/v2beta1

autoscaling/v2beta2

batch/v1

batch/v1beta1

certificates.k8s.io/v1

certificates.k8s.io/v1beta1

coordination.k8s.io/v1

coordination.k8s.io/v1beta1

discovery.k8s.io/v1beta1

events.k8s.io/v1

events.k8s.io/v1beta1

extensions/v1beta1

flowcontrol.apiserver.k8s.io/v1beta1

networking.k8s.io/v1

networking.k8s.io/v1beta1

node.k8s.io/v1

node.k8s.io/v1beta1

policy/v1beta1

rbac.authorization.k8s.io/v1

rbac.authorization.k8s.io/v1beta1

scheduling.k8s.io/v1

scheduling.k8s.io/v1beta1

storage.k8s.io/v1

storage.k8s.io/v1beta1

v1

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后,附一张自己面试前准备的脑图:

image

面试前一定少不了刷题,为了方便大家复习,我分享一波个人整理的面试大全宝典

  • Java核心知识整理

image

  • Spring全家桶(实战系列)

image.png

Step3:刷题

既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。

以下是我私藏的面试题库:

image

很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。

最后祝愿各位身体健康,顺利拿到心仪的offer!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。

以下是我私藏的面试题库:

[外链图片转存中…(img-03cg6Uhy-1713461063083)]

很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。

最后祝愿各位身体健康,顺利拿到心仪的offer!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 19
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值