在 Kubernetes 中检查镜像签名

news/2024/7/7 14:33:26 标签: docker, java, kubernetes, 区块链, css

之前连续写了几篇 Shell Operator 的东西,后来又写了一篇 cosign 的介绍,细心的读者可能会猜到,最终我的目的就是会用 Shell Operator 结合 cosign 来检查镜像的签名,以此保障镜像的完整性——是的,这个过程相当容易。

Shell Operator 除了初期的调度和 Prometheus Exporter 功能之外,最近又加入了 Validating Webhook 的能力,和以前的几篇文章的内容结合起来,能非常轻松地实现检查镜像签名的能力。

简单地设计如下功能:

  1. 创建密钥对,以私钥对镜像进行签名,公钥用 Secret 的形式保存进集群。

  2. 创建 Shell Operator 配置,只针对打出了特定标签的命名空间中的对象进行检查。

  3. 配置保存为 Configmap。

  4. 部署 Shell Operator 组成的 Validating Webhook.

  5. 在特定命名空间中创建工作负载,触发校验功能。

  6. Shell Operator 使用公钥进行校验,校验通过才能成功运行。

我们给 Webhook 编写如下配置:

  config:
    namespace:
      labelSelector:
        matchLabels:
          signed: "required"
    rules:
    - apiGroups:   ["apps"]
      apiVersions: ["v1"]
      operations:  ["CREATE", "UPDATE"]
      resources:   ["deployments"]
      scope:       "Namespaced"

配置内容声明,仅对标签为 signed=required 的命名空间中的 Deployments 对象生效。将配置文件生成为 Configmap,保存到 Configmap 中,运行期加载为存储卷,然后就可以在代码中如此调用:

parser = argparse.ArgumentParser(description='Pod hook for Shell-Operator')
parser.add_argument('--config', action='store_true')
args = parser.parse_args()
CONFIG_FILE = os.getenv("CONFIG_FILE", "/etc/cosign-validator/config.yaml")if args.config:    with open(CONFIG_FILE) as cfg:
        print("".join(cfg.readlines()))
    sys.exit(0)

公钥文件保存在 Secret 里,这里假设我们加载为 /etc/cosign-keys/cosign.pub,就可以用如下代码进行校验:

# 响应文件名称RESPONSE_FILE = os.getenv("VALIDATING_RESPONSE_PATH")
...
    key_file = "/etc/cosign-keys/cosign.pub"
    for container in json_obj[0]["review"]["request"]["object"]["spec"]["template"]["spec"]["containers"]:
        image = container["image"]        try:            # TODO: Read public key name from annotation
            subprocess.check_call([                "/usr/local/bin/cosign",                "verify", "-key", key_file, image])        except subprocess.CalledProcessError:
            message = image            break...with open(RESPONSE_FILE, "w") as writer:    if len(message) == 0:
        writer.write('{"allowed":true}')    else:
        content = '{"allowed":false, "message":"The image ' + message +' is not signed properly"}'
        writer.write(content)

主体代码之后,就需要考虑如何部署了,首先要生成 Docker 镜像:

# 一段构建,生成 cosign
FROM golang:1.16.2-alpine3.13 as builder
RUN apk add --no-cache git=2.30.2-r0
RUN go install github.com/sigstore/cosign/cmd/cosign@v0.1.0
# 二段构建,加入代码到 hooks 目录
FROM flant/shell-operator:v1.0.0-rc.2
RUN apk --no-cache add python3=3.8.8-r0
COPY --from=builder /go/bin/cosign /usr/local/bin
COPY cosign-validation.py /hooks


Webhook 需要根据服务名称等信息生成证书用于和 API Server 之间的通信过程,此处略过,可以直接参看源代码。另外为了能够注册服务,还需要一个具备权限的 ClusterRole:

apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  name: cosign-validator
rules:
- apiGroups: ["admissionregistration.k8s.io"]
  resources:
  - validatingwebhookconfigurations
  verbs:
  - list
  - create
  - update

这些对象和证书可以用 Helm Chart 组织起来,进行集成安装部署。

部署成功后,可以尝试分别使用签名和未签名镜像进行部署,会看到未签名镜像会被拒绝。详细操作和测试过程可以参见视频。


http://www.niftyadmin.cn/n/1708507.html

相关文章

K8S 生态周报| Rancher Desktop v0.1.0 抢先一览

“「K8S 生态周报」内容主要包含我所接触到的 K8S 生态相关的每周值得推荐的一些信息。欢迎订阅知乎专栏「k8s生态」[1]。”Trivy v0.17 正式发布Trivy 是一款由 Aqua Security 开源的镜像漏洞安全扫描程序,在之前的周报中我已经介绍过它很多次了,特别方…

Containerd 1.5 发布:重磅支持 docker-compose!

2021 年 5 月 4 日,Containerd 1.5 正式发布[1],该版本默认启用了 OCIcrypt 解密功能,并引入了对 NRI、zstd 和 FreeBSD jails 的支持,同时还简化了对 Containerd 的贡献流程。下面就来看看具体更新了哪些功能吧。默认 OCIcrypt 解…

【粉丝福利】免费赠票 - 专享 Gdevops 全球敏捷运维峰会

2021 Gdevops全球敏捷运维峰会 - 广州站,将在5月28日盛大举办。Gdevops经过创办6年成功举行近20场大会的经验积淀,本次峰会结合行业趋势与技术热点,精选出最能破解当下运维、数据库、金融科技领域核心痛难点的干货议题,不容错过的…

5.20 宠粉福利,云原生书籍免费送!

大家好,我是张晋涛!我最近主要专注在 Apache APISIX Ingress 等开源项目。这是一个自定义的 Kubernetes Ingress controller 可以更好的利用 Apache APISIX 作为高性能网关。对此项目还不了解的小伙伴欢迎前往 GitHub 了解,地址是&#xff1a…

最强 CNI 基准测试:Cilium 网络性能分析

作者:Thomas Graf译者:罗煜、张亮,均来自 KubeSphere 团队Thomas Graf 是 Cilium 的联合创始人,同时也是 Cilium 母公司 Isovalent[1] 的 CTO 和联合创始人。此前 Thomas 曾先后在 Linux 内核[2]的网络、安全和 eBPF 领域从事了 1…

K8S 生态周报| Cilium v1.10.0 有史以来性能最优

“「K8S 生态周报」内容主要包含我所接触到的 K8S 生态相关的每周值得推荐的一些信息。欢迎订阅知乎专栏「k8s生态」[1]。”KIND v0.11.0 正式发布KIND (Kubernetes In Docker)[2] 关注我的小伙伴想必已经都很熟悉了,这是我一直都在参与也用的非常多的一个项目&…

(译)Kubernetes 单点登录详解

纯翻译,未测试,点击“阅读原文”查看原文。本文中我们将会为 Kuebernetes 构建一个完备的单点登录系统,这个系统会为 kubectl、Web 应用的 Ingress,以及 Docker 镜像仓库和 Gitea 提供服务,本文中会涉及多数单点登录模…