Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[fluent-bit] optional podVersionLabel feature flag to include app.kubernetes.io/version applied to all pods #576

Open
wants to merge 7 commits into
base: main
Choose a base branch
from

Conversation

jhulick
Copy link

@jhulick jhulick commented Dec 9, 2024

What this PR does / why we need it:

  • It adds common labels to metadata labels in the pod spec. The main reasoning is to persist the app.kubernetes.io/version and app.kubernetes.io/name labels to the pod for standardization. Per docs, (https://kubernetes.io/docs/concepts/overview/working-with-objects/common-labels/#labels) "In order to take full advantage of using these labels, they should be applied on every resource object.".

  • Improves traceability throughout the application. Ex. via Istio/Kiali dashboard.

@jhulick jhulick force-pushed the pod-labels-with-version branch from 8fc59e1 to 0f788a9 Compare December 9, 2024 20:05
@jhulick jhulick changed the title Pod labels with version [fluent-bit] Pod labels include app.kubernetes.io/version Dec 9, 2024
Copy link
Collaborator

@stevehipwell stevehipwell left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the PR @jhulick but as was the case for Metrics Server this isn't a desirable change for the chart. If you make this change optional and off by default I think it would be OK; my preference would be to use a value like verbosePodLabels: false.

@jhulick
Copy link
Author

jhulick commented Dec 11, 2024

@stevehipwell, I was hesitant to create this PR for that reason, but since fluent-bit is data plane rather than control plane I thought it would be considered acceptable in this case, unless there are other reasons? Is it primarily due to telemetry latency? But I'll update per your proposed suggested.

@jhulick jhulick requested a review from stevehipwell December 11, 2024 19:15
@jhulick jhulick force-pushed the pod-labels-with-version branch from 460d134 to aeb9cc3 Compare December 11, 2024 19:16
@jhulick jhulick changed the title [fluent-bit] Pod labels include app.kubernetes.io/version [fluent-bit] optional verbosePodLabels to include app.kubernetes.io/version applied to all pods Dec 11, 2024
@stevehipwell
Copy link
Collaborator

@jhulick I don't think the labels are a good idea, but even if they were we'd still be looking to follow the "principal of least astonishment"; so making them opt in is the only real way of introducing this change.

@jhulick jhulick force-pushed the pod-labels-with-version branch from 4e7b751 to dc8b8bd Compare December 12, 2024 18:37
@jhulick jhulick requested a review from stevehipwell December 12, 2024 18:38
@stevehipwell
Copy link
Collaborator

@jhulick looking at this again with fresh eyes am I right in summarising your requirement as only needing the app.kubernetes.io/version label adding to pods so they can be part of an Istio mesh?

If we ignore the question of "why"; would the best implementation for this not be to have a podVersionLabel: false value which if set to true just adds the singular label? The concept of verbose pod labels is fuzzy and could be co-opted for other purposes, with unintended consequences.

@jhulick
Copy link
Author

jhulick commented Jan 7, 2025

@stevehipwell, yes, only the app.kubernetes.io/version label is needed in this case since the app label is already supplied via selectorLabels. Istio recommends adding app and version labels to pods to attach this information to telemetry. Kiali relies on correctness of these labels for several features...

"...would the best implementation for this not be to have a podVersionLabel: false value which if set to true just adds the singular label?" Yes, I think this is a better approach. I'll update the PR.

@jhulick jhulick force-pushed the pod-labels-with-version branch from 1e9851b to bc94292 Compare January 8, 2025 18:03
Signed-off-by: jeremy.hulick <jeremy.hulick@gmail.com>
Signed-off-by: jeremy.hulick <jeremy.hulick@gmail.com>
…nabled in values

Signed-off-by: jeremy.hulick <jeremy.hulick@gmail.com>
Signed-off-by: jeremy.hulick <jeremy.hulick@gmail.com>
Signed-off-by: jeremy.hulick <jeremy.hulick@gmail.com>
Signed-off-by: jeremy.hulick <jeremy.hulick@gmail.com>
Signed-off-by: jeremy.hulick <jeremy.hulick@gmail.com>
@jhulick jhulick force-pushed the pod-labels-with-version branch from f979637 to eb35d7d Compare January 9, 2025 18:22
@jhulick jhulick changed the title [fluent-bit] optional verbosePodLabels to include app.kubernetes.io/version applied to all pods [fluent-bit] optional podVersionLabel feature flag to include app.kubernetes.io/version applied to all pods Jan 13, 2025
Copy link
Collaborator

@stevehipwell stevehipwell left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jhulick I've added some comments and it looks like you need to rebase this PR locally.

Comment on lines +54 to +63
{{/*
Verbose Pod labels
*/}}
{{- define "fluent-bit.podVersionLabel" -}}
{{ include "fluent-bit.selectorLabels" . }}
{{- if .Chart.AppVersion }}
app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
{{- end }}
{{- end -}}

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can this be removed?

@@ -27,7 +27,7 @@ spec:
template:
metadata:
labels:
{{- include "fluent-bit.selectorLabels" . | nindent 8 }}
{{- include (ternary "fluent-bit.podVersionLabel" "fluent-bit.selectorLabels" .Values.podVersionLabel) . | nindent 8 }}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This would make more sense being below the standard labels and implemented with the following pattern.

      {{- if and .Values.podVersionLabel .Chart.AppVersion }}
        app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
      {{- end }}

@@ -30,7 +30,7 @@ spec:
template:
metadata:
labels:
{{- include "fluent-bit.selectorLabels" . | nindent 8 }}
{{- include (ternary "fluent-bit.podVersionLabel" "fluent-bit.selectorLabels" .Values.podVersionLabel) . | nindent 8 }}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same as above.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants