Security Best Practices
Best practices for securing Flux deployments.
Flux has a multi-component design, and integrates with many other systems.
This document outlines an overview of security considerations for Flux components, project processes, artifacts, as well as Flux configurable options and what they enable for both Kubernetes cluster and external system security.
See our security processes document for vulnerability reporting, handling, and disclosure of information for the Flux project and community.
Please also have a look at our security-related blog posts. We are writing there to inform you what we are doing to keep Flux and you safe!
The Flux CLI and the controllers’ images are signed using Sigstore Cosign and GitHub OIDC. The container images along with their signatures are published on GitHub Container Registry and Docker Hub.
To verify the authenticity of Flux’s container images, install cosign and run:
$ COSIGN_EXPERIMENTAL=1 cosign verify ghcr.io/fluxcd/source-controller:v0.21.1
Verification for ghcr.io/fluxcd/source-controller:v0.21.1 --
The following checks were performed on each of these signatures:
- The cosign claims were validated
- Existence of the claims in the transparency log was verified offline
- Any certificates were verified against the Fulcio roots.
We also wrote a blog post which discusses the this in some more detail.
For the Flux project we publish a Software Bill of Materials (SBOM) with each release. The SBOM is generated with Syft in the SPDX format.
The spdx.json
file is available for download on the GitHub release page e.g.:
curl -sL https://github.com/fluxcd/flux2/releases/download/v0.25.3/flux_0.25.3_sbom.spdx.json | jq
Please also refer to the blog post which discusses the idea and value of SBOMs.
The controller deployments are configured in conformance with the Kubernetes restricted pod security standard:
While Flux integrates with other systems it is built on Kubernetes core controller-runtime and properly adheres to Kubernetes security model including RBAC 1.
Flux installs a set of RBAC manifests. These include:
crd-controller
ClusterRole
, which:crd-controller
ClusterRoleBinding
:crd-controller
ClusterRole
abovecluster-reconciler
ClusterRoleBinding
:cluster-admin
ClusterRole
kustomize-controller
and helm-controller
Flux uses these two ClusterRoleBinding
strategies in order to allow for clear access separation using tools
purpose-built for policy enforcement (OPA, Kyverno, admission controllers).
For example, the design allows all controllers to access Flux CRDs (binds to crd-controller
ClusterRole
),
but only binds the Flux reconciler controllers for Kustomize and Helm to cluster-admin
ClusterRole
,
as these are the only two controllers that manage resources in the cluster.
However in a
soft multi-tenancy setup,
Flux does not reconcile a tenant’s repo under the cluster-admin
role.
Instead, you specify a different service account in your manifest, and the Flux controllers will use
the Kubernetes Impersonation API under cluster-admin
to impersonate that service account 2.
In this way, policy restrictions for this service account are applied to the manifests being reconciled.
If the binding is not defined for the correct service account and namespace, it will fail.
The roles and permissions for this multi-tenancy approach
are described in detail here:
https://github.com/fluxcd/flux2-multi-tenancy.
Beyond the security features that Flux has backed into it, there are further best practices that can be implemented to ensure your Flux deployment is as secure as it can be. For more information, checkout the Flux Security Best Practices.
However, by design cross-namespace references are an exception to RBAC. Platform admins have to option to turnoff cross-namespace references as described in the installation documentation. ↩︎
Platform admins have to option to enforce impersonation as described in the installation documentation. ↩︎
Best practices for securing Flux deployments.