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

DB/messaging: do we want to have generic client (instance) id attribute #729

Closed
lmolkova opened this issue Feb 9, 2024 · 3 comments
Closed

Comments

@lmolkova
Copy link
Contributor

lmolkova commented Feb 9, 2024

We have db.cosmosdb.client_id and messaging.client_id.
they are used to record unique identifier of a client instance - usually something random.
Kafka or other messaging systems have limits on number of consumers per partition and it could be helpful during debugging to see how many instances are created. Also useful to know if application creates clients too frequently (e.g. per request instead of a singleton instance).

If we're going to have more of individual systems/semconvs introducing it, it could make sense to have a generic attribute.

Related: open-telemetry/opentelemetry-specification#2015

@pyohannes
Copy link
Contributor

I agree that a general definition would be good. However, there might be challenges to find a generic definition of what a "client instance" is.

@pyohannes
Copy link
Contributor

From the messaging SIG: this doesn't necessarily block stability, as we can exempt the messaging.client_id from the initial set of stable attributes.

@lmolkova lmolkova moved this from V1 - Stable Semantics to Post-stability in Spec: Messaging Semantics Feb 15, 2024
@trask trask moved this to Post Stability in Database Client Semantic Conventions Feb 21, 2024
@lmolkova
Copy link
Contributor Author

lmolkova commented Jun 20, 2024

Based on DB and Messaging SIG discussions:

  • it's very hard to describe what client instance id means in a generic case.
  • client namespace is used to describe initiator of a remote call
  • the use-case for SDK client instance id does not seem to be very generic
    • it helps to detect if someone creates excessive amount of client instances, but it might be visible by other means such as number of open connections, memory usage, profiling, etc
    • it also helpful as a correlation mechanism to debug SDK client state issues, but again the same information might be available by other means (correlated logs, connection level details, etc)
  • It's unlikely that someone would build dashboards or alerts using the SDK client instance id attribute.

Given that we don't have a compelling use-case for a generic attribute or a descriptive and non-controversial name for it, I'm going to close this issue.

@github-project-automation github-project-automation bot moved this from Post Stability to Done in Database Client Semantic Conventions Jun 20, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Development

No branches or pull requests

3 participants