Metadata labeling

Recently I was tasked with implementing a metadata labeling standard across all of our kubernetes resources. Currently we exclusively only deploy helm charts spread across ArgoCD and Waypoint. Thinking about ways to implement this I came up with a few, re-usable ideas which would need to be introduced to every Helm chart we are installing.

Policy management

First Iā€™ll dive into how we will enforce labeling going forward. Since we are setting a new standard with these metadata labels, it was important to introduce a new resource policy, to prevent and error out any new services deployed that donā€™t adhere to the policy. Iā€™ll deploy this in audit mode initially, and then eventually flip the switch to enforce once we are confident everything we expect to abide to the policy is following it.

Why not just manage common labels in helm?

The problem on relying solely on helm to define these standardized labels, is that it would be impossible to achieve consistency amongst all the third party helm charts we use. Different chart maintainers may have different ways of organizing and defining their helm charts.

Hereā€™s where Kustomize comes in

I havenā€™t really had much exposure to Kustomize before, but looking at its features, it seems to be the right fit for this use-case. The ability to consistently apply standardized overlays across various charts, with support for filtering resources. Kustomize seems to elegantly give use what we need.

One thing Iā€™ve neglected to mention is our current setup. While I havenā€™t used Kustomize yet, after doing some research, it looks like it would be tricky to leverage Kustomize for labels that are more dynamic (i.e environment-based).

Overcoming the hurdle with dynamic variables

References