Skip to content

Commit

Permalink
Allow prefixing of rollout-group value and ingester name
Browse files Browse the repository at this point in the history
Signed-off-by: Brian Oldfield <[email protected]>
  • Loading branch information
boldfield committed Dec 10, 2024
1 parent 0d53408 commit be968c7
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 6 deletions.
2 changes: 2 additions & 0 deletions charts/tempo-distributed/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -509,6 +509,7 @@ The memcached default args are removed and should be provided manually. The sett
| global.image.registry | string | `"docker.io"` | Overrides the Docker registry globally for all images, excluding enterprise. |
| global.priorityClassName | string | `nil` | Overrides the priorityClassName for all pods |
| global_overrides.per_tenant_override_config | string | `"/runtime-config/overrides.yaml"` | |
| ingester.addIngesterNamePrefix | bool | `false` | Optionally allow adding 'tempo-' prefix to Ingester StatefulSet names, this is helpful when running multiple LTGM components in a single namespace. |
| ingester.affinity | string | Soft node and soft zone anti-affinity | Affinity for ingester pods. Passed through `tpl` and, thus, to be configured as string |
| ingester.annotations | object | `{}` | Annotations for the ingester StatefulSet |
| ingester.appProtocol | object | `{"grpc":null}` | Adds the appProtocol field to the ingester service. This allows ingester to work with istio protocol selection. |
Expand Down Expand Up @@ -551,6 +552,7 @@ The memcached default args are removed and should be provided manually. The sett
| ingester.priorityClassName | string | `nil` | The name of the PriorityClass for ingester pods |
| ingester.replicas | int | `3` | Number of replicas for the ingester |
| ingester.resources | object | `{}` | Resource requests and limits for the ingester |
| ingester.rolloutGroupPrefix | string | `null` | Optionally add supplied prefix to the Ingester StatefulSet rollout-group label. This is helpful when running multiple LTGM components in a single namespace. |
| ingester.service.annotations | object | `{}` | Annotations for ingester service |
| ingester.service.internalTrafficPolicy | string | `"Cluster"` | https://kubernetes.io/docs/concepts/services-networking/service-traffic-policy/ |
| ingester.service.type | string | `"ClusterIP"` | Type of the service: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types |
Expand Down
24 changes: 18 additions & 6 deletions charts/tempo-distributed/templates/ingester/_helpers-ingester.tpl
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ Params:
- key: rollout-group
operator: In
values:
- ingester
- "{{ include "ingester.rolloutGroupNamePrefix" .ctx | trim }}{{ .component }}"
- key: zone
operator: NotIn
values:
Expand Down Expand Up @@ -70,8 +70,8 @@ ingester labels
*/}}
{{- define "ingester.labels" -}}
{{- if and .ctx.Values.ingester.zoneAwareReplication.enabled .rolloutZoneName }}
name: {{ printf "%s-%s" .component .rolloutZoneName }}
rollout-group: {{ .component }}
name: "{{ include "ingester.namePrefix" .ctx | trim }}{{ .component | trim }}-{{ .rolloutZoneName }}"
rollout-group: "{{ include "ingester.rolloutGroupNamePrefix" .ctx | trim }}{{ .component }}"
zone: {{ .rolloutZoneName }}
{{- end }}
helm.sh/chart: {{ include "tempo.chart" .ctx }}
Expand Down Expand Up @@ -123,7 +123,7 @@ app.kubernetes.io/component: {{ .component }}
{{- if not .component }}
{{- printf "Component name cannot be empty if rolloutZoneName (%s) is set" .rolloutZoneName | fail }}
{{- end }}
rollout-group: {{ .component }}
rollout-group: "{{ include "ingester.rolloutGroupNamePrefix" .ctx | trim }}{{ .component }}"
zone: {{ .rolloutZoneName }}
{{- end }}
{{- end -}}
Expand Down Expand Up @@ -174,8 +174,20 @@ app.kubernetes.io/part-of: memberlist
{{- if not .component }}
{{- printf "Component name cannot be empty if rolloutZoneName (%s) is set" .rolloutZoneName | fail }}
{{- end }}
name: "{{ .component }}-{{ .rolloutZoneName }}" {{- /* Currently required for rollout-operator. https://github.com/grafana/rollout-operator/issues/15 */}}
rollout-group: ingester
name: "{{ include "ingester.namePrefix" .ctx | trim }}{{ .component }}-{{ .rolloutZoneName }}"{{- /* Currently required for rollout-operator. https://github.com/grafana/rollout-operator/issues/15 */}}
rollout-group: "{{ include "ingester.rolloutGroupNamePrefix" .ctx | trim }}{{ .component }}"
zone: {{ .rolloutZoneName }}
{{- end }}
{{- end -}}

{{- define "ingester.rolloutGroupNamePrefix" -}}
{{- if .Values.ingester.rolloutGroupPrefix }}
{{ .Values.ingester.rolloutGroupPrefix }}-
{{- end }}
{{- end -}}

{{- define "ingester.namePrefix" -}}
{{- if .Values.ingester.addNamePrefix }}
tempo-
{{- end }}
{{- end -}}
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,11 @@ spec:
selector:
matchLabels:
{{- include "ingester.selectorLabels" $dict | nindent 6}}
{{- if not .Values.ingester.zoneNamespacedServiceName }}
serviceName: ingester
{{- else }}
serviceName: tempo-ingester-{{ $zoneName }}
{{- end }}
podManagementPolicy: Parallel
updateStrategy:
{{- if .Values.ingester.zoneAwareReplication.enabled }}
Expand Down
6 changes: 6 additions & 0 deletions charts/tempo-distributed/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -294,6 +294,12 @@ ingester:
# If set to "-", then use `storageClassName: ""`, which disables dynamic provisioning
# If undefined or set to null (the default), then fall back to the value of `ingester.persistentVolume.storageClass`.
storageClass: null
# optionally allow adding 'tempo-' prefix to ingester name label
addNamePrefix: false
# optionally allow adding arbitrary prefix to the ingester rollout-group label
rolloutGroupPrefix: ''
# optionally namespace StatefulSet serviceName with zone. ex: temp-ingester-zone-a
zoneNamespacedServiceName: false

# Configuration for the metrics-generator
metricsGenerator:
Expand Down

0 comments on commit be968c7

Please sign in to comment.