Skip to content

Commit

Permalink
Allow to annotate pods on change using a different label
Browse files Browse the repository at this point in the history
This change allows users to optionally specify a different label (than the
one used to watch receiver pods) for annotating pods on hashring change.

This is useful in a separate Thanos receiver router and ingestor setup:
https://thanos.io/tip/proposals-accepted/202012-receive-split.md/ where
we need to watch a different set of ingestor pods to update the hashring,
but the hashring is consumed by a different set of router pods.

Signed-off-by: Ratnadeep Debnath <[email protected]>
  • Loading branch information
rtnpro committed Dec 22, 2023
1 parent c57219e commit 23f3429
Showing 1 changed file with 10 additions and 1 deletion.
11 changes: 10 additions & 1 deletion main.go
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ type CmdConfig struct {
AllowOnlyReadyReplicas bool
AllowDynamicScaling bool
AnnotatePodsOnChange bool
AnnotatePodsLabel string
ScaleTimeout time.Duration
}

Expand All @@ -93,6 +94,7 @@ func parseFlags() CmdConfig {
flag.BoolVar(&config.AllowOnlyReadyReplicas, "allow-only-ready-replicas", false, "Populate only Ready receiver replicas in the hashring configuration")
flag.BoolVar(&config.AllowDynamicScaling, "allow-dynamic-scaling", false, "Update the hashring configuration on scale down events.")
flag.BoolVar(&config.AnnotatePodsOnChange, "annotate-pods-on-change", false, "Annotates pods with current timestamp on a hashring change")
flag.StringVar(&config.AnnotatePodsLabel, "annotate-pods-label", "", "The label pods must have to be annotated with current timestamp by the controller on a hashring change.")
flag.DurationVar(&config.ScaleTimeout, "scale-timeout", defaultScaleTimeout, "A timeout to wait for receivers to really start after they report healthy")
flag.Parse()

Expand Down Expand Up @@ -152,6 +154,7 @@ func main() {
labelValue: labelValue,
allowOnlyReadyReplicas: config.AllowOnlyReadyReplicas,
annotatePodsOnChange: config.AnnotatePodsOnChange,
annotatePodsLabel: config.AnnotatePodsLabel,
allowDynamicScaling: config.AllowDynamicScaling,
scaleTimeout: config.ScaleTimeout,
}
Expand Down Expand Up @@ -337,6 +340,7 @@ type options struct {
allowOnlyReadyReplicas bool
allowDynamicScaling bool
annotatePodsOnChange bool
annotatePodsLabel string
scaleTimeout time.Duration
}

Expand Down Expand Up @@ -743,11 +747,16 @@ func (c *controller) saveHashring(ctx context.Context, hashring []receive.Hashri
func (c *controller) annotatePods(ctx context.Context) {
annotationKey := fmt.Sprintf("%s/%s", c.options.labelKey, "lastControllerUpdate")
updateTime := fmt.Sprintf("%d", time.Now().Unix())
annotatePodsLabel := fmt.Sprintf("%s=%s", c.options.labelKey, c.options.labelValue)

if c.options.annotatePodsLabel != "" {
annotatePodsLabel = c.options.annotatePodsLabel
}

// Select pods that have a controllerLabel matching ours.
podList, err := c.klient.CoreV1().Pods(c.options.namespace).List(ctx,
metav1.ListOptions{
LabelSelector: fmt.Sprintf("%s=%s", c.options.labelKey, c.options.labelValue),
LabelSelector: annotatePodsLabel,
})
if err != nil {
level.Error(c.logger).Log("msg", "failed to list pods belonging to controller", "err", err)
Expand Down

0 comments on commit 23f3429

Please sign in to comment.