国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

一篇帶給你KubeBuilder 簡明教程

開源
這篇文章主要講解了 kubebuilder的安裝使用方式,以及涉及到的一些簡單的概念,項目目錄結構的說明.

[[398025]]

Operator 概述

Operator 是 Kubernetes 的擴展軟件,它利用 定制資源 管理應用及其組件。Operator 遵循 Kubernetes 的理念,特別是在控制器 方面[^1]

k8s 的是一個高度自動化的系統,其中涵蓋了常見應用程序所需的大部分功能,例如服務發現,負載均衡,HPA等等,這些功能是由 k8s 自帶的一些控制器實現的,但是需求總是永無止境的,當我們有類似需求但是 k8s 又無法很好的滿足的時候我們就可以使用 Operator 和 Custome Resource(自定義資源)來達到類似的效果。

例如常見的需求就有部署一個數據庫,節點自動化運維,日志采集組件配置等等

從 Operator 理念的提出到現在已經有了很多工具可以幫助我們快速低成本的開發,其中最常用的就是 CoreOS 開源的 operator-sdk[^3]和 k8s sig 小組維護的 kubebuilder[^2],我們這個系列選用 kubebuilder。

開始之前我們先了解兩個馬上就會涉及到的核心概念

GV & GVK & GVR

GV: Api Group & Version

  • API Group 是相關 API 功能的集合
  • 每個 Group 擁有一或多個 Versions

GVK: Group Version Kind

  • 每個 GV 都包含 N 個 api 類型,稱之為 Kinds,不同 Version 同一個 Kinds 可能不同

GVR: Group Version Resource

  • Resource 是 Kind 的對象標識,一般來 Kind 和 Resource 是 1:1 的,但是有時候存在 1:n 的關系,不過對于 Operator 來說都是 1:1 的關系

舉個🌰,我們在 k8s 中的 yaml 文件都有下面這么兩行,例如上篇文章我們部署的 nginx deployment

  1. apiVersion: apps/v1 # 這個是 GV,G 是 apps,V 是 v1 
  2. kind: Deployment    # 這個就是 Kind 
  3. sepc:               # 加上下放的 spec 就是 Resource了 
  4.   ... 

根據 GVK K8s 就能找到你到底要創建什么類型的資源,根據你定義的 Spec 創建好資源之后就成為了 Resource,也就是 GVR。GVK/GVR 就是 K8s 資源的坐標,是我們創建/刪除/修改/讀取資源的基礎[^4]。

KubeBuilder 簡明教程

安裝

訪問官方倉庫下載已經編譯好的二進制文件: Releases · kubernetes-sigs/kubebuilder (github.com)

  • 本文編寫的時候 kubebuilder 已經推出了 v3.0.0-rc.0 版本,所以為了避免剛寫完新版就已經 release 了的尷尬情況,本文直接使用的是 3.0 版本
  • 下載好了之后記得將對應文件加入 PATH 當中

安裝成功之后使用 kubebuilder version 可以查看安裝的版本信息

  1. ❯ kubebuilder version 
  2. Version: main.version{KubeBuilderVersion:"3.0.0-rc.0", KubernetesVendor:"1.19.2", GitCommit:"90fe4124c4c6965c6bfac63339888956952cda90", BuildDate:"2021-04-08T17:36:28Z", GoOs:"linux", GoArch:"amd64"

項目初始化

先創建一個空文件夾,然后在文件夾內執行下方命令

  1. kubebuilder init --domain lailin.xyz --repo github.com/mohuishou/blog-code/k8s-operator/02-kubebuilder 
  • –-domain lailin.xyz 我們的項目的域名
  • --repo xxx 是倉庫地址,同時也是 go mode中的repo地址

如果你 golang 版本過低或者過高都有可能出現下方的錯誤信息,我這里是因為使用的 1.16 版本太高了

  1. 2021/04/25 20:47:14 failed to initialize project: unable to run pre-scaffold tasks of "base.go.kubebuilder.io/v3": go version 'go1.16' is incompatible because 'requires 1.13 <= version < 1.16'. You can skip this check using the --skip-go-version-check flag 

這種情況下可以添加 --skip-go-version-check 忽略這個錯誤,但是還是建議使用官方推薦的版本

  1. kubebuilder init --domain lailin.xyz --repo github.com/mohuishou/blog-code/k8s-operator/02-kubebuilder --skip-go-version-check 

項目目錄

  1. ├── Dockerfile 
  2. ├── Makefile # 這里定義了很多腳本命令,例如運行測試,開始執行等 
  3. ├── PROJECT  # 這里是 kubebuilder 的一些元數據信息 
  4. ├── config 
  5. │   ├── default    # 一些默認配置 
  6. │   ├── manager    # 部署 crd 所需的 yaml 
  7. │   ├── prometheus # 監控指標數據采集配置 
  8. │   └── rbac # 部署所需的 rbac 授權 yaml 
  9. ├── go.mod 
  10. ├── go.sum 
  11. ├── hack 
  12. │   └── boilerplate.go.txt 
  13. └── main.go 

創建 api

  1. kubebuilder create api --group apps --version v1 --kind Application 

執行之后我們可以發現項目結構發生了一些變化

  1. ├── api 
  2. │   └── v1 
  3. │       ├── application_types.go # 這里是定義 spec 的地方 
  4. │       ├── groupversion_info.go # GV 的定義,一般無需修改 
  5. │       └── zz_generated.deepcopy.go 
  6. ├── config 
  7. │   ├── crd # 自動生成的 crd 文件,不用修改這里,只需要修改了 v1 中的 go 文件之后執行 make generate 即可 
  8. │   ├── default 
  9. │   ├── manager 
  10. │   ├── prometheus 
  11. │   ├── rbac 
  12. │   └── samples # 這里是 crd 示例文件,可以用來部署到集群當中 
  13. ├── controllers 
  14. │   ├── application_controller.go # 在這里實現 controller 的邏輯 
  15. │   └── suite_test.go # 這里寫測試 

實現 Controller

定義 CR

  1. // api/v1/application_types.go 
  2.  
  3. // ApplicationSpec defines the desired state of Application 
  4. type ApplicationSpec struct { 
  5.  // INSERT ADDITIONAL SPEC FIELDS - desired state of cluster 
  6.  // Important: Run "make" to regenerate code after modifying this file 
  7.  
  8.  // Product 該應用所屬的產品 
  9.  Product string `json:"product,omitempty"

修改之后我們執行一下 make manifests generate 可以發現已經生成了相關的字段,并且代碼中的字段注釋也就是 yaml 文件中的注釋

  1. # config/crd/bases/apps.lailin.xyz_applications.yaml 
  2. ...... 
  3.    properties: 
  4.               product: 
  5.                 description: Product 該應用所屬的產品 
  6.                 type: string 
  7. ...... 

實現 controller

kubebuilder 已經幫我們實現了 Operator 所需的大部分邏輯,我們只需要在 Reconcile 中實現業務邏輯就行了

  1. // controllers/application_controller.go 
  2.  
  3. func (r *ApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { 
  4.  _ = r.Log.WithValues("application", req.NamespacedName) 
  5.  
  6.  r.Log.Info("app changed""ns", req.Namespace) 
  7.  
  8.  return ctrl.Result{}, nil 

邏輯修改好之后,我們先執行 make install 安裝 CRD,然后執行 make run運行 controller

  1. go run ./main.go 
  2. 2021-04-25T21:55:55.578+0800    INFO    controller-runtime.metrics     metrics server is starting to listen     {"addr"":8080"
  3. 2021-04-25T21:55:55.579+0800    INFO    setup   starting manager 
  4. 2021-04-25T21:55:55.579+0800    INFO    controller-runtime.manager     starting metrics server  {"path""/metrics"
  5. 2021-04-25T21:55:55.579+0800    INFO    controller-runtime.manager.controller.application       Starting EventSource    {"reconciler group""apps.lailin.xyz""reconciler kind""Application""source""kind source: /, Kind="
  6. 2021-04-25T21:55:55.680+0800    INFO    controller-runtime.manager.controller.application       Starting Controller     {"reconciler group""apps.lailin.xyz""reconciler kind""Application"
  7. 2021-04-25T21:55:55.680+0800    INFO    controller-runtime.manager.controller.application       Starting workers        {"reconciler group""apps.lailin.xyz""reconciler kind""Application""worker count": 1} 

然后我們部署一個測試的 crd kubectl apply -f config/samples/apps_v1_application.yaml

  1. apiVersion: apps.lailin.xyz/v1 
  2. kind: Application 
  3. metadata: 
  4.   name: application-sample 
  5. spec: 
  6.   # Add fields here 
  7.   product: test 

然后可以看到之前寫的日志邏輯已經觸發

  1. 2021-04-25T21:57:12.618+0800    INFO    controllers.Application app changed     {"ns""default"

Kubebuilder 注釋

在生成的代碼當中我們可以看到很多 //+kubebuilder:xxx 開頭的注釋,對 Go 比較熟悉的同學應該知道這些注釋是給對應的代碼生成器服務的,在 Go 中有一個比較常用的套路就是利用 go gennerate生成對應的 go 代碼。

kubebuilder 使用 controller-gen 生成代碼和對應的 yaml 文件,這其中主要包含 CRD 生成、驗證、處理還有 WebHook 的 RBAC 的生成功能,下面我簡單介紹一下,完整版可以看 kubebuilder 的官方文檔

CRD 生成

  • //+kubebuilder:subresource:status 開啟 status 子資源,添加這個注釋之后就可以對 status進行更新操作了
  • //+groupName=nodes.lailin.xyz 指定 groupname
  • //+kubebuilder:printcolumn 為 kubectl get xxx 添加一列,這個挺有用的
  • ......

CRD 驗證,利用這個功能,我們只需要添加一些注釋,就給可以完成大部分需要校驗的功能

  • //+kubebuilder:default:= 給字段設置默認值
  • //+kubebuilder:validation:Pattern:=string 使用正則驗證字段
  • ......

Webhook

  • //+kubebuilder:webhook 用于指定 webhook 如何生成,例如我們可以指定只監聽 Update 事件的 webhook

RBAC 用于生成 rbac 的權限

  • //+kubebuilder:rbac

總結

這篇文章主要講解了 kubebuilder的安裝使用方式,以及涉及到的一些簡單的概念,項目目錄結構的說明,下一篇文章我們就一起來實現一個真實的 Operator 需求

參考文獻

[^1]: Operator 模式 | Kubernetes:

https://kubernetes.io/zh/docs/concepts/extend-kubernetes/operator/

[^2]: kubebuilder 官方文檔, 這個是 master 分支的文檔,待 3.0 發布后去掉 master 即可:

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

[^3]: operator-sdk:

https://sdk.operatorframework.io/

[^4]: 深入解析 Kubebuilder:讓編寫 CRD 變得更簡單:

https://developer.aliyun.com/article/719215

 

責任編輯:姜華 來源: mohuishou
相關推薦

2021-05-11 09:31:31

kustomizeoperator kubernetes

2022-07-06 07:57:37

Zookeeper分布式服務框架

2021-07-12 06:11:14

SkyWalking 儀表板UI篇

2021-10-14 09:58:24

消息中間件ActiveMQ Java

2021-09-18 07:43:33

ApolloJava配置中心

2021-07-08 07:30:13

Webpack 前端Tree shakin

2023-03-13 09:31:04

2021-04-14 07:55:45

Swift 協議Protocol

2021-10-28 08:51:53

GPIO軟件框架 Linux

2021-04-23 08:59:35

ClickHouse集群搭建數據庫

2022-02-25 15:50:05

OpenHarmonToggle組件鴻蒙

2021-05-08 08:36:40

ObjectString前端

2022-04-29 14:38:49

class文件結構分析

2022-03-22 09:09:17

HookReact前端

2021-01-28 08:55:48

Elasticsear數據庫數據存儲

2024-06-13 08:34:48

2021-06-21 14:36:46

Vite 前端工程化工具

2021-04-01 10:51:55

MySQL鎖機制數據庫

2021-04-08 11:00:56

CountDownLaJava進階開發

2022-02-17 08:53:38

ElasticSea集群部署
點贊
收藏

51CTO技術棧公眾號

国产高清自拍视频在线观看| 青青草原综合久久大伊人精品 | 亚洲国内精品在线| 色偷偷免费视频| 国产精品毛片无遮挡高清| 大桥未久一区二区三区| 久久精品一区| 99久久无色码| 亚洲v在线看| 国产精品羞羞答答| av中字幕久久| 国产精品永久在线| 影视一区二区| 91九色视频在线| 在线看片不卡| 国产高清自拍一区| 99pao成人国产永久免费视频| av成人午夜| 日韩视频一区| 日本亚洲导航| 国产一区二区在线电影| 中文字幕av导航| 国产高清不卡二三区| 日韩a级在线观看| 久久久www成人免费毛片麻豆| 日韩精品视频久久| 国产精品青草综合久久久久99| 先锋成人影音| 亚洲va在线va天堂| 日本在线免费中文字幕| 日韩精品一区二区三区中文精品 | 国产乱码精品一区二区三区亚洲人| 亚洲午夜精品久久久久久久久久久久| 亚洲www.| 色综合男人天堂| 亚洲人成精品久久久 | 亚洲一区二区三区免费在线观看 | 亚洲精品网址| 欧美极品jizzhd欧美| 久久一综合视频| 手机成人av在线| 99久久免费视频.com| 久久黄色片视频| 亚洲欧美视频在线观看| 婷婷国产在线| 精品国产青草久久久久福利| 欧美国产日韩电影| 26uuu亚洲伊人春色| 国产精品二区不卡| 欧美日韩国产一二| 26uuu色噜噜精品一区二区| 日韩精品视频网| 99999色| 最新国产在线拍揄自揄视频| 国产91丝袜在线观看| 日韩免费在线免费观看| 国产精品一区二区三区视频网站| 亚洲人成网站在线| 大香煮伊手机一区| 久久成人免费网| 欧美另类一区| 欧美成人xxxx| 俺去亚洲欧洲欧美日韩| av网站手机在线观看| 大桥未久av一区二区三区中文| 日韩精品资源二区在线| 羞羞的网站在线观看| 精品国产百合女同互慰| 日本伊人久久| 9久久婷婷国产综合精品性色| 日韩精品在线免费观看| 99精品免费视频| 亚洲一区二区三区精品在线观看| 欧美一卡二卡在线观看| 奇米一区二区| 伊人色综合影院| 一区二区国产视频| 全球av集中精品导航福利| 国产蜜臀在线| 久久久亚洲成人| 中文字幕在线不卡一区二区三区| 日韩美香港a一级毛片| 中文字幕免费高| 国产精品丝袜一区| 亚洲欧美日韩国产一区| 视频三区在线观看| 国产伦精品一区二区三区视频青涩| 国产精品一区二区小说| 制服丝袜日韩国产| 精品影片在线观看的网站| 一区二区av| 日本电影亚洲天堂一区| 成人免费在线电影网| 性欧美大战久久久久久久免费观看| 亚洲图片激情小说| 8av国产精品爽爽ⅴa在线观看| 国产chinese精品一区二区| 国产精品国产三级国产普通话三级| 华人av在线| 91在线精品观看| 日本一区二区三区四区在线视频| 草草影院在线| 国严精品久久久久久亚洲影视| 中文字幕制服丝袜一区二区三区 | 无码人妻精品一区二区三区99v| 亚洲国产精华液网站w| heyzo高清中文字幕在线| 国产中文字幕日韩| 亚洲欧洲性图库| 国产精品视频一区视频二区| 一本久道久久综合狠狠爱亚洲精品| 午夜视频在线观看一区| 欧美丝袜美腿| 国产成人精品无码播放| 日韩av网站大全| 国产精品一区毛片| 国产三级在线免费| 国产在线视频91| 亚洲sss视频在线视频| 日本韩国欧美超级黄在线观看| 国产精品亚洲αv天堂无码| 精品调教chinesegay| 夜夜嗨网站十八久久| 国产一级二级三级在线观看| 国产精品亚洲欧美导航| 夜夜精品视频一区二区| 国产欧美日韩一区二区三区四区| 羞羞的视频免费| 欧日韩在线观看| 亚洲精品视频在线观看免费| 香蕉视频一区| 超碰在线公开免费| 国产精品视频区1| 亚洲国产欧美另类丝袜| 精品国产欧美日韩| 嫩草嫩草嫩草| 国产精品丝袜久久久久久高清| 尤物在线观看一区| 成人黄色小视频| 国产视频福利在线| 日本免费高清不卡| 亚洲精品在线观看www| 成人动漫精品一区二区| 国产精品一级在线观看| 日本www.色| 国产精品福利网| 欧美日韩美女在线观看| 亚洲电影av| 日本а中文在线天堂| www.av毛片| 555www成人网| 午夜精品久久久久久久久久久| 久久精品高清| 米奇777四色精品人人爽| 日韩欧美亚洲在线| 一区二区三区视频免费在线观看| 91亚洲国产成人精品一区二区三| 国产精品传媒| 国产小视频免费在线网址| 日本一区不卡| www.欧美精品一二三区| 亚洲欧美日韩成人高清在线一区| 欧美永久精品| 亚洲欧美小说色综合小说一区| 精品无码一区二区三区在线| 97福利一区二区| 在线观看91视频| 国产真实乱对白精彩久久| 日本精品一区二区三区在线观看视频| 欧美高清xxxxxkkkkk| 国产精品亚洲综合| 亚洲性无码av在线| 樱桃视频在线观看一区| 伊人成人在线视频| 免费污视频在线一区| 日本高清好狼色视频| 色狠狠久久av五月综合| 欧美成人sm免费视频| 欧美性xxxxxxxxx| 极品美女销魂一区二区三区| 国产精品美女久久久久| 天堂√在线中文官网在线| 久久99蜜桃综合影院免费观看| 亚洲精品一区二区三区不| 国产精品灌醉下药二区| 亚洲欧美日本日韩| 日韩欧美高清一区二区三区| 亚洲mv在线| 久久久久久久久久久99| 国产精品久久久久久久美男| 欧美一区二区三区在线看 | 四虎影视永久免费在线观看一区二区三区| 亚洲男人天天操| 五月激情丁香一区二区三区| 国产精品99久久久久久久vr| 青青草成人影院| 成人在线免费电影网站| 日本大臀精品| 亚洲一区日韩精品| 亚洲欧洲精品一区二区|