跳到主要内容

FIPS 140-2 启用

FIPS 140-2 是美国联邦政府的安全标准,用于批准加密模块。本文解释了如何使用 FIPS 验证的加密库构建 RKE2。

使用 FIPS 兼容的 Go 编译器

你可以在此处找到所使用的 Go 编译器。系统的每个组件都是用这个编译器的版本来构建的,与其他情况下使用的标准 Go 编译器版本一致。

这个版本的 Go 用经过 FIPS 验证的 BoringCrypto 模块取代了标准 Go 加密库。有关详细信息,请参阅 GoBoring 的 readme。该模块最初由 NIST 验证为 Rancher Kubernetes 加密库,用于支持更广泛的系统。但是,由于 SP 800-56A Rev3 引入的更改,此验证现在已成为历史。目前正在进行此模块的重新验证,以使该模块恢复到活动的 FIPS 140-2 状态。

集群组件中的 FIPS 支持

RKE2 系统的大部分组件都是使用 GoBoring Go 编译器实现静态编译的。从组件的角度来看,RKE2 被分成了若干部分。下面的列表包含了这些部分和相关的组件。

  • Kubernetes

    • API Server
    • Controller Manager
    • Scheduler
    • Kubelet
    • Kube Proxy
    • Metric Server
    • Kubectl
  • Helm Chart

    • Flannel
    • Calico
    • CoreDNS

运行时

为了确保系统架构的各方面都使用符合 FIPS 140-2 标准的算法实现,RKE2 运行时包含了用符合 FIPS 标准的 Go 编译器静态编译的实用程序。这确保了从 Kubernetes 守护程序到容器协调机制的所有层面都是合规的。

  • etcd
  • containerd
    • containerd-shim
    • containerd-shim-runc-v1
    • containerd-shim-runc-v2
    • ctr
  • crictl
  • runc

CNI

从 v1.21.2 开始,RKE2 支持通过 --cni 标志选择不同的 CNI,并绑定了多个 CNI,包括 Canal(默认)、Calico、Cilium 和 Multus。其中,只有 Canal(默认)是为符合 FIPS 标准而重建的。

Ingress

RKE2 附带了 NGINX 作为其默认的 ingress provider。从 v1.21+ 开始,此组件符合 FIPS 标准。NGINX ingress 有两个主要的子组件:

  • controller - 负责监控/更新 Kubernetes 资源并相应地配置 server
  • server - 负责接收和路由流量

Controller 是用 Go 编写的,因此使用我们 FIPS 兼容的 Go 编译器进行编译。

server 是用 C 编写的,还需要 OpenSSL 才能正常运行。因此,它利用 FIPS 验证的 OpenSSL 版本来实现 FIPS 合规。