首页 > 后端开发 > Golang > 正文

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

P粉602998670
发布: 2025-08-18 17:08:01
原创
237人浏览过

准入控制器是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 main

import (
    "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"`
}
登录后复制

解析建议:

降重鸟
降重鸟

要想效果好,就用降重鸟。AI改写智能降低AIGC率和重复率。

降重鸟 308
查看详情 降重鸟
  • 使用标准库中的
    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/v1
kind: ValidatingWebhookConfiguration
metadata:
  name: my-validator
webhooks:
  - name: my-validator.example.com
    clientConfig:
      service:
        namespace: default
        name: my-admission-service
      caBundle: <base64 encoded CA cert>
    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 解析动态准入控制的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号