【golang-技巧】-自定义k8s-operator-by kubebuilder

0.背景&参考

link : https://github.com/guangtouwangba/blog-example/tree/master/k8s-operator

https://juejin.cn/post/7192525316890296380

https://book.kubebuilder.io/quick-start

1.download

bash 复制代码
sudo curl -L -o kubebuilder https://go.kubebuilder.io/dl/latest/$(go env GOOS)/$(go env GOARCH) && sudo chmod +x kubebuilder && sudo mv kubebuilder /usr/local/bin/
shell 复制代码
kubebuilder version

2.simple operator

shell 复制代码
go mod init dongchen.org/k8s
kubebuilder init --plugins go/v3 --domain dongchen.org --owner 'dongchen'

# gvk
kubebuilder create api --group k8s --version v1beta1 --kind AlertManagerConsole  

# 修改代码后 make manifests

# 安装crd
make install 

# 本地运行 
# 如果不行 打包镜像放到k8s中
make run 

3.结论

我的理解 本质是是 k8s 提供crd 机制 ,kubebuilder 提供了一个脚手架

那么我们通过 list/watch 自定义crd ,从而实现 自定义crd 要管理/创建 不同类型的工作负载或pod

实现自定义的pod管理机制

或着 实现自己应用平台 一整套逻辑 减轻实施部署同学或运维同学 压力

目前也想实现一套operator ,但是目前工作平台太过复杂,通过operator 实现管理组件 不太现实

有更好的建议也可以聊一下

相关推荐
我不会编程55510 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
李少兄10 小时前
Unirest:优雅的Java HTTP客户端库
java·开发语言·http
云上艺旅10 小时前
K8S学习之基础七十四:部署在线书店bookinfo
学习·云原生·容器·kubernetes
无名之逆10 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust
似水এ᭄往昔10 小时前
【C语言】文件操作
c语言·开发语言
啊喜拔牙11 小时前
1. hadoop 集群的常用命令
java·大数据·开发语言·python·scala
xixixin_11 小时前
为什么 js 对象中引用本地图片需要写 require 或 import
开发语言·前端·javascript
W_chuanqi11 小时前
安装 Microsoft Visual C++ Build Tools
开发语言·c++·microsoft
anlogic11 小时前
Java基础 4.3
java·开发语言
A旧城以西12 小时前
数据结构(JAVA)单向,双向链表
java·开发语言·数据结构·学习·链表·intellij-idea·idea