K8s-CRD实战

CRD

CRD的全称是CustomResourceDefinition,是Kubernetes为提高可扩展性,

让开发者去自定义资源(如Deployment,StatefulSet等)的一种方法.

Controller

controller是由controller-manager进行管理,通过API Server提供的接口实时监控整个集群的每一个资源对象的当前状态,

当状态发生变化时,会尝试通过CRUD操作将系统状态修复到"期望状态".

整理架构图

组件解释

Informer即自带缓存和索引机制,可以触发Handler的客户端库.使用了Reflector包,

它是一个可以通过ListAndWatch机制获取并监视API对象变化的客户端封装.

Reflector和Informer之间,用到了一个"增量先进先出队列"进行协同.

而Informer与要编写的控制循环之间,则使用了一个工作队列来进行协同.

在实际应用中,除了控制循环之外的所有代码,实际上都是 Kubernetes 为你自动生成的,

即:pkg/client/{informers, listers, clientset}里的内容。

源码解析

https://jimmysong.io/kubernetes-handbook/develop/client-go-informer-sourcecode-analyse.html

案例参考

https://github.com/kubernetes/sample-controller, 注意go版本需要选用1.22

shell 复制代码
# assumes you have a working kubeconfig, not required if operating in-cluster
go build -o sample-controller .

# run sample-controller
./sample-controller -kubeconfig=$HOME/.kube/config

# create a CustomResourceDefinition
kubectl create -f artifacts/examples/crd-status-subresource.yaml

# create a custom resource of type Foo
kubectl create -f artifacts/examples/example-foo.yaml

# check deployments created through the custom resource
kubectl get deployments

案例效果

使用k edit调整pod实例数量

案例补充

GOPATH, GOROOT, GOBIN的区别

GOPATH: Go第三方库安装路径, go mod推行后,会使用索引查询该路径下的依赖包

GOROOT: Go安装路径

GOBIN: Go可执行二进制文件安装路径

Go Mod管理依赖解释

shell 复制代码
require (
	B vx.x.x
	B1 vx.x.x //indirect
	B2 vx.x.x //indirect
)
shell 复制代码
require (
	B vx.x.x
	B2 vx.x.x //indirect
)
相关推荐
Java后端的Ai之路4 小时前
Kubernetes是什么?(小白入门版)
云原生·容器·kubernetes·教程
heimeiyingwang4 小时前
【架构实战】编排vs协同:微服务通信架构选型
微服务·云原生·架构
木雷坞4 小时前
视觉算法环境 Docker 镜像拉取失败排查
运维·人工智能·docker·容器
空中海4 小时前
第二篇:注册中心篇 — Nacos 与 Eureka 服务注册发现
spring boot·云原生·eureka
瀚高PG实验室5 小时前
安全版V4.5版本docker容器license过期问题处理步骤
安全·docker·容器·瀚高数据库
007张三丰6 小时前
系统架构设计师范文4:论微服务架构及其应用
微服务·云原生·架构·软考·系统架构设计师
AI攻城狮6 小时前
Human-in-the-Loop 是生产环境不可妥协的环节
云原生
筱_智6 小时前
Docker学习-超详细-通俗易懂(从入门到精通)
学习·docker·容器
EAIReport7 小时前
Docker与K8s核心解析:共同性、差异性及实战适配指南
docker·容器·kubernetes
长安链开源社区7 小时前
动手开发 | 如何通过k8s部署长安链
云原生·容器·kubernetes·区块链