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

Leader Election Extension #34460

Open
3 tasks
skhalash opened this issue Aug 7, 2024 · 15 comments
Open
3 tasks

Leader Election Extension #34460

skhalash opened this issue Aug 7, 2024 · 15 comments
Labels
Accepted Component New component has been sponsored

Comments

@skhalash
Copy link

skhalash commented Aug 7, 2024

The purpose and use-cases of the new component

There can be a use case where one needs to run components in an HA mode. But currently running multiple instances of components like k8sclusterreceiver would
cause collection of duplicate metrics. In order to be able to run such receivers in an HA mode one needs to make sure only one receiver is active. This can be achieved by utilizing the leader election mechanism provided by Kubernetes client library.

The support for extension can be implemented as an extension so that any component that wants to leverage leader election can use it easily.

Example configuration for the component

receivers:
  k8sclusterreceiver:
    leader_elector: leader_elector
extensions:
  leader_elector:
    auth_type: kubeConfig
    lease_name: foo
    lease_namespace: default

Telemetry data types supported

traces, metrics, and logs

Is this a vendor-specific component?

  • This is a vendor-specific component
  • If this is a vendor-specific component, I am a member of the OpenTelemetry organization.
  • If this is a vendor-specific component, I am proposing to contribute and support it as a representative of the vendor.

Code Owner(s)

@skhalash @a-thaler @rakesh-garimella

Sponsor (optional)

No response

Additional context

I work at SAP on a project called Kyma: https://kyma-project.io/#/. In Kyma, we recently developed such a receiver and we are already testing it out in a production setup: https://github.com/kyma-project/opentelemetry-collector-components/tree/main/receiver/singletonreceivercreator.

We’ve noticed discussions in the community about introducing leader election in the k8sobjects and k8scluster receivers. That's why we believe that a generic mechanism could be quite beneficial. If there’s interest, we are ready to contribute it to the Open Telemetry project.

@skhalash skhalash added needs triage New item requiring triage Sponsor Needed New component seeking sponsor labels Aug 7, 2024
@ChrsMark
Copy link
Member

ChrsMark commented Aug 7, 2024

That sounds interesting. A similar approach is used in Metricbeat for covering the cluster level metrics collection when running as part of a Daemonset.

II assume we want to achieve something similar here where the Collector will be running only as a Daemonset and the leader will be responsible for enabling the k8sclusterreceiver and k8sobjectsreceiver?

While this is useful from user experience perspective, from my past experience, it can be problematic when it comes to scale.
When you deploy the Collector as a Daemonset you set the resource limits according to the Pod's needs. However one of the Pods will be the leader and hence would require extra resources. In order to support this you need to increase the resource requests/limits for the whole Daemonset, but not all of the Pods will actually need those resources. This can be confusing. In addition, such a feature might also affect the load that the Collectors put to the K8s API. I have seen such issues in the past but I don't have something specific to share here. So in summary, such a feature would need to explicitly document the pros/cons etc (and maybe be tested accordingly) and properly set the expectations for the users.

@skhalash
Copy link
Author

Hey @ChrsMark! Thanks for the feedback. Yes, exactly the leader is responsible for enabling a sub-receiver (such as k8sclusterreceiver and k8sobjectsreceiver) if the collector is running as a DaemonSet or a Deployment.

Yes, I fully agree with the concerns about resource limits/requests. However, as you said, it should be properly documented. Not sure if there is a way to workaround it.

Regarding putting some extra load on the k8s API - do you mean querying/updating leases?

@ChrsMark
Copy link
Member

Regarding putting some extra load on the k8s API - do you mean querying/updating leases?

@skhalash yes, but this is something that can also be properly documented along with some perf tests results so as users be aware of any possible impact to their clusters.

@dmitryax
Copy link
Member

dmitryax commented Oct 23, 2024

Why does it have to be a separate receiver? I think this should be an extension providing an interface that any receiver can connect to to check if it's a leader (have to do the work) or not (do nothing). I would be happy to sponsor and review that

@skhalash
Copy link
Author

Hey @dmitryax! Thanks so much for your response! We’d be happy to contribute such a component. I don’t have much experience with extensions—would this mean that every receiver needing this functionality would require code modifications? Implementing it as a delegating receiver, similar to receiver-creator, could avoid it.

@dmitryax
Copy link
Member

Modifying code is fine - better than having two similar receivers. It's better to write some code, but keep the user interface clean. Restricting it to receiver_creator, we won't be able to use leader election for receivers that don't work with receiver creator, for example https://github.com/open-telemetry/opentelemetry-collector-contrib/tree/main/receiver/k8seventsreceiver, or don't need to use it all, e.g. collecting data from a static endpoint. Also, future of receiver_creator is unclear. We might take a different approach to discovery and consolidate all scraping receivers in one, see open-telemetry/opentelemetry-collector#11238

@skhalash
Copy link
Author

Thanks for the response! We'll explore the idea of implementing leader election as an extension instead of a receiver and will get back to you.

@skhalash
Copy link
Author

skhalash commented Nov 6, 2024

Hey @dmitryax,

We're exploring a specific use case and wanted to get your thoughts. The scenario involves multiple receivers within a single running collector instance that may need to operate in singleton mode, using leader election. To support this, each receiver might need its own lease, allowing each to be managed by a different leader.

We're considering two possible approaches:

  1. Embedding the lease configuration directly within each interested receiver’s configuration:
receivers:
  k8s_cluster:
    singleton:
      lease_name: foo
      lease_namespace: default
  k8s_events:
    singleton:
      lease_name: bar
      lease_namespace: default
extensions:
  singleton:
  1. Creating multiple instances of a new extension, like singleton/foo and singleton/bar, each referenced by its respective receiver:
receivers:
  k8s_cluster:
    singleton:
      name: singleton/foo
  k8s_events:
    singleton:
      name: singleton/bar
extensions:
  singleton/foo:
    lease_name: foo
    lease_namespace: default
  singleton/bar:
    lease_name: bar
    lease_namespace: default

The second approach seems simpler to implement. However, from what I’ve seen, there aren’t any examples in the wild of multiple instances of extensions being registered. Do you think this approach would be feasible?

@JaredTan95
Copy link
Member

This is a very interesting feature, and many of the plugins in otel col contrib are currently restricted to running on a single instance.

@skhalash
Copy link
Author

We did some investigation and agree that implementing leader election as an extension is indeed a cleaner solution. We will provide a PR with the implementation soon.

@chenlujjj
Copy link
Contributor

hello @skhalash wondering what's the progress there ?

@rakesh-garimella
Copy link

rakesh-garimella commented Jan 7, 2025

Hi @chenlujjj I am actively working on this. I plan to create a PR with the implementation of the extension in this week.

@rakesh-garimella
Copy link

Initial Implementation for the extension has been done here. @dmitryax please have a look.

@dmitryax dmitryax added Accepted Component New component has been sponsored and removed Sponsor Needed New component seeking sponsor labels Jan 14, 2025
@dmitryax
Copy link
Member

dmitryax commented Jan 14, 2025

I sponsor this component

@rakesh-garimella
Copy link

rakesh-garimella commented Jan 16, 2025

As per review comments and guidelines the PR needs to be divided into several small PRs.
First PR is created here here

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Accepted Component New component has been sponsored
Projects
None yet
Development

No branches or pull requests

7 participants