如何用Golang编写K8s Admission Controller 解析动态准入控制

准入控制器是kubernetes中用于拦截并处理资源请求的插件,实现动态准入控制的关键手段之一是使用golang编写外部webhook类型的控制器。具体步骤包括:1.搭建基础结构,使用golang写一个监听/mutate和/validate路径的https webhook服务;2.解析请求内容,从admissionreview结构中提取资源信息;3.编写mutating逻辑(如为pod添加标签)和validating逻辑(如拒绝无资源限制的容器);4.部署到集群,配置validatingwebhookconfiguration并生成tls证书,确保服务可被访问。通过以上步骤即可完成基本的admission controller实现。

如何用Golang编写K8s Admission Controller 解析动态准入控制

编写 Kubernetes 的 Admission Controller 是实现动态准入控制的关键手段之一。Golang 作为 Kubernetes 的原生开发语言,自然是首选。下面从几个关键点出发,带你了解如何用 Golang 实现一个基本的 K8s Admission Controller。

如何用Golang编写K8s Admission Controller 解析动态准入控制

准入控制器是什么?为什么需要它?

Admission Controller(准入控制器)是 Kubernetes 中用于拦截并处理资源请求的插件。它可以修改或拒绝 API 请求,在对象被持久化之前进行额外校验或注入配置。例如:

如何用Golang编写K8s Admission Controller 解析动态准入控制在 Pod 创建时自动注入 sidecar 容器拒绝没有指定资源限制的容器校验自定义 CRD 是否符合规范

Kubernetes 支持内置和外部准入控制器,我们这里说的是构建外部的、可部署的 webhook 类型控制器。

立即学习“go语言免费学习笔记(深入)”;

搭建基础结构:写一个简单的 HTTP Server

Admission Controller 本质上是一个 HTTPS Webhook 服务,监听特定路径并返回响应。你不需要自己实现整个 Kubernetes API,只需要处理

/mutate

/validate

路径下的请求。

如何用Golang编写K8s Admission Controller 解析动态准入控制

package mainimport (    "fmt"    "net/http"    "github.com/gin-gonic/gin")func main() {    r := gin.Default()    r.POST("/mutate", mutateHandler)    r.POST("/validate", validateHandler)    fmt.Println("Starting server on :443")    // 注意:需要 TLS 证书    r.RunTLS(":443", "server.crt", "server.key")}

关键点:

必须使用 HTTPS,否则 Kubernetes 不会信任接口路径必须与 Kubernetes 配置中一致控制器应支持

/healthz

端点用于健康检查

解析请求内容:理解 AdmissionReview 结构

Kubernetes 发送的请求体是

AdmissionReview

对象,包含请求元数据和资源信息。你需要从中提取出原始资源内容(如 Pod、Deployment 等)。

type AdmissionReview struct {    Request *AdmissionRequest `json:"request,omitempty"`    Response *AdmissionResponse `json:"response,omitempty"`}type AdmissionRequest struct {    UID string `json:"uid"`    Kind metav1.GroupVersionKind `json:"kind"`    Resource metav1.GroupVersionResource `json:"resource"`    Object runtime.RawExtension `json:"object"`}

解析建议:

使用标准库中的

json.Unmarshal

k8s.io/apimachinery

工具解析提取

Object.Raw

字段后,再反序列化为具体的资源类型(如

Pod

)注意处理不同版本资源(比如 v1.Pod vs apps/v1.Deployment)

编写 Mutating 和 Validating 逻辑

Mutating 示例:给所有 Pod 添加标签

func mutatePod(raw []byte) ([]byte, error) {    var pod corev1.Pod    if err := json.Unmarshal(raw, &pod); err != nil {        return nil, err    }    if pod.Labels == nil {        pod.Labels = make(map[string]string)    }    pod.Labels["managed-by"] = "my-admission-controller"    return json.Marshal(pod)}

然后构造 Patch,并封装成

AdmissionResponse

返回。

Validating 示例:拒绝没有资源限制的容器

遍历每个容器,检查

Resources.Limits

是否为空:

for _, container := range pod.Spec.Containers {    if container.Resources.Limits.Cpu().IsZero() ||       container.Resources.Limits.Memory().IsZero() {        return false, "container missing resource limits"    }}

验证失败时,返回

AdmissionResponse{Allowed: false}

即可。

部署到集群:配置 ValidatingWebhookConfiguration

写好代码只是第一步,还需要在 Kubernetes 中注册这个 webhook。创建一个

ValidatingWebhookConfiguration

MutatingWebhookConfiguration

,示例片段如下:

apiVersion: admissionregistration.k8s.io/v1kind: ValidatingWebhookConfigurationmetadata:  name: my-validatorwebhooks:  - name: my-validator.example.com    clientConfig:      service:        namespace: default        name: my-admission-service      caBundle:     rules:      - apiGroups: [""]        apiVersions: ["v1"]        resources: ["pods"]        operationTypes: ["CREATE"]    failurePolicy: Fail    sideEffects: None    timeoutSeconds: 5

注意点:

需要生成并部署 TLS 证书webhook 服务要能被 Kubernetes 控制平面访问(内网 IP 或公网域名)可以同时部署多个 webhook,按顺序执行

总结一下

实现一个 Admission Controller 并不复杂,但需要注意很多细节。主要包括:

实现一个安全的 HTTPS Webhook 服务正确解析和响应

AdmissionReview

编写清晰的 mutating 和 validating 逻辑部署并配置 webhook 到 Kubernetes 集群中

基本上就这些步骤。虽然看起来有点多,但每一步都不难,只要一步步来就行。

以上就是如何用Golang编写K8s Admission Controller 解析动态准入控制的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1398738.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月15日 15:38:18
下一篇 2025年12月15日 15:38:31

相关推荐

  • Golang模块管理完整指南 从入门到精通

    Go模块通过go.mod和go.sum文件实现项目级依赖管理,解决了GOPATH时代依赖版本冲突与全局共享的痛点。go.mod记录模块路径和依赖版本,go.sum校验依赖完整性,确保构建确定性与安全性;配合go mod tidy、replace等命令,可高效管理依赖更新与替换,提升项目可维护性和团队…

    好文分享 2025年12月15日
    000
  • Go语言在Windows系统中的环境配置与编译运行问题排查指南

    本教程旨在解决Go语言在Windows系统下常见的编译及运行错误,特别是由于多版本Go安装或环境变量配置不当导致的问题。文章将详细指导用户如何彻底清理现有Go环境,进行规范化安装,并验证和修正GOROOT、GOBIN及PATH等关键环境变量,确保Go开发环境的稳定与一致性,从而避免因环境冲突引发的编…

    2025年12月15日
    000
  • Golang SQL注入防护 预处理参数化查询

    使用预处理和参数化查询可有效防御SQL注入,Golang中通过database/sql包的Prepare和Query方法实现,确保用户输入作为数据而非代码执行,从根本上隔离风险。 Golang中防御SQL注入的核心策略是使用预处理(Prepared Statements)和参数化查询,它能有效区分代…

    2025年12月15日
    000
  • 怎样用Golang开发eBPF工具 集成libbpf和BCC工具链

    Go语言通过libbpf-go或gobpf库在用户态加载和管理eBPF程序,利用其并发、静态编译和系统编程优势,实现高性能、易部署的eBPF工具开发,但需依赖C编写内核态代码,且Go绑定库在部分特性支持上仍有局限。 在Golang中开发eBPF工具,本质上是利用Go语言强大的系统编程能力,作为用户空…

    2025年12月15日
    000
  • Go语言在Windows平台编译与执行错误排查及环境配置指南

    本文旨在解决Go语言在Windows系统上常见的编译与执行错误,特别是因多版本安装冲突或环境变量配置不当导致的问题。核心解决方案包括彻底卸载所有Go版本、清理残留文件,然后重新安装单一、正确的Go版本,并规范配置GOROOT、GOBIN和PATH等关键环境变量,确保开发环境的稳定性和一致性。 引言:…

    2025年12月15日
    000
  • Go语言:获取文件最后访问时间与计算时间差

    本文将详细介绍如何在Go语言中获取文件的最后访问时间,并演示如何将此时间与当前时间进行比较,以计算时间差。我们将利用os.Stat函数获取文件的FileInfo结构,并通过其内部的纳秒级时间戳来构建time.Time对象,进而进行精确的时间差计算。 在go语言中,对文件系统进行操作是常见的需求,其中…

    2025年12月15日
    000
  • 解决Windows 64位Go编译与执行错误:环境配置深度解析

    本文旨在解决Windows 64位系统上Go程序编译及执行时遇到的常见错误,特别是由于多版本Go安装和环境变量配置冲突导致的问题。核心解决方案包括彻底卸载所有现有Go版本、执行干净的单版本安装,并正确配置GOROOT、GOBIN和PATH等关键环境变量,确保Go工具链的正确性和一致性,从而实现Go程…

    2025年12月15日
    000
  • Go语言:解决终端输入回显导致内容重复显示的问题

    本文深入探讨了Go语言中从标准输入读取数据时,因终端默认回显机制导致输入内容重复显示的问题。通过分析bufio.NewReader的局限性,文章详细介绍了如何利用golang.org/x/crypto/terminal包中的ReadPassword函数来禁用本地回显,从而实现单次、干净的输入显示。教…

    2025年12月15日
    000
  • Go语言在Windows平台编译与运行环境配置疑难解析

    本教程旨在解决Go语言在Windows系统上因多版本安装或环境变量配置不当导致的编译与运行错误。文章详细阐述了常见的环境冲突现象,并提供了一套系统性的解决方案,包括彻底卸载旧版本、清理残留文件、正确安装单一稳定版本以及精确配置GOROOT、GOBIN和PATH环境变量,确保Go开发环境的稳定与一致性…

    2025年12月15日
    000
  • Go语言中如何禁用标准输入回显:安全读取敏感输入

    本文探讨Go语言中读取标准输入时,如何解决终端默认回显导致输入内容重复显示的问题。通过介绍Go标准库bufio的ReadString方法的工作原理,并引入golang.org/x/term包中的ReadPassword函数,演示如何在不回显的情况下安全地读取用户输入,尤其适用于密码或敏感数据的场景。…

    2025年12月15日
    000
  • Go语言:解决标准输入重复显示问题并实现无回显读取

    本文深入探讨了在Go语言中使用bufio.ReadString从标准输入读取用户输入时,终端可能出现字符重复显示的问题。文章分析了问题产生的原因,并详细介绍了如何利用golang.org/x/term包中的ReadPassword函数来实现无回显的用户输入读取,从而有效解决重复显示困扰。教程提供了清…

    2025年12月15日
    000
  • Go Struct 初始化:探索构造函数模式与工厂函数

    Go 语言不提供像其他面向对象语言那样的隐式构造函数来初始化结构体。相反,Go 推崇使用显式的“工厂函数”(Fac++tory Functions)来创建和初始化结构体实例。这些函数通常以 New 开头,负责设置默认值、执行必要的配置,并返回一个结构体实例或其指针,这是 Go 中管理结构体生命周期和…

    2025年12月15日
    000
  • Go Struct 初始化:探索构造函数模式与工厂函数实践

    Go语言中没有传统面向对象语言的类构造函数概念。为了实现结构体的初始化,Go推崇使用“工厂函数”模式,通常命名为Newc++tName>。这些函数负责创建并返回一个初始化好的结构体实例(通常是指针),是Go语言中进行结构体初始化的标准和推荐方式,提供了清晰的创建语义和灵活的初始化逻辑。 Go语…

    2025年12月15日
    000
  • Go语言:在终端中禁用回显读取用户输入

    本文旨在解决Go语言中从标准输入读取用户数据时,终端默认回显导致内容重复显示的问题。我们将深入探讨使用标准库bufio包进行输入时出现双重回显的原因,并重点介绍如何利用golang.org/x/term包中的ReadPassword函数实现无回显的输入。文章将提供详细的代码示例、使用注意事项及最佳实…

    2025年12月15日
    000
  • Golang实现RPC服务怎么做 使用net/rpc构建分布式系统

    使用golang的net/rpc构建rpc服务的关键步骤是:1. 定义符合func (t t) methodname(args args, reply *reply) error签名的服务方法;2. 服务端通过rpc.register注册服务实例并监听tcp连接,使用rpc.serveconn处理每…

    2025年12月15日
    000
  • Golang如何测试CLI交互流程 使用expect库模拟用户输入场景

    使用 expect 库测试 cli 交互流程的关键步骤是:1. 安装 expect 及其依赖;2. 编写或构建被测 cli 程序;3. 启动子进程并创建 expect 实例;4. 使用 expectstring 匹配提示信息;5. 使用 sendline 模拟用户输入;6. 再次使用 expects…

    2025年12月15日 好文分享
    000
  • 怎样实现Golang的全局错误处理器 设计应用级的错误恢复机制

    设计全局错误处理器是为了统一错误格式、自动记录日志、提供恢复机制并避免重复代码。1. 定义标准错误结构体apperror,包含code、message和err字段,并实现error()方法以符合error接口。2. 在web应用中使用中间件捕获http请求中的错误,通过defer recover处理…

    2025年12月15日 好文分享
    000
  • Golang模块与包的区别是什么 解析go.mod与package的关系

    包是代码逻辑分组,模块是包的集合与版本管理单元,go.mod文件定义模块元信息及依赖关系,实现可重复构建与依赖管理。 一个Go 包 (package)是Go语言中代码组织的基本单位,它由同一目录下的源文件组成,通常代表着一组相关的功能。而一个Go 模块 (module)则是一个或多个Go包的集合,它…

    2025年12月15日
    000
  • Go语言:获取文件最后访问时间与时间比较

    Go语言中,通过os.Stat获取os.FileInfo接口,进而利用平台特定的系统调用(如syscall.Stat_t)可以获取文件的最后访问时间(atime)。本文将详细介绍如何获取此时间戳,并演示如何将其与当前时间进行比较,同时探讨跨平台兼容性及注意事项。 1. 理解文件时间戳 在文件系统中,…

    2025年12月15日
    000
  • Golang微服务如何监控性能 使用Prometheus采集指标数据

    要有效监控go微服务性能并用prometheus采集指标,需集成prometheus客户端库暴露指标接口,配置prometheus抓取数据,并结合grafana可视化。1. 引入prometheus go客户端库,定义counter、gauge、histogram等指标类型;2. 在代码中记录关键指…

    2025年12月15日 好文分享
    000

发表回复

登录后才能评论
关注微信