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

Manifest for metrics endpoint #70

Open
sed-i opened this issue Oct 9, 2024 · 3 comments
Open

Manifest for metrics endpoint #70

sed-i opened this issue Oct 9, 2024 · 3 comments

Comments

@sed-i
Copy link

sed-i commented Oct 9, 2024

Problem

Currently, there is no obvious way to obtain the metrics an application exposes, without first deploying the application.

Proposal

Come up with a standard for documenting the metrics an application exposes. This could take different forms, for example:

  • A METRICS.md file with a sample contents of /metrics.
  • Store organically to the app, in the same repo (and optionally link there from the dockerhub image page).
  • A build artifact of a release, adjacent to the binary/packages published as part of the release.

Value proposition

  1. Deprecation of metrics, or introduction of new metrics would be readily noticed.
  2. Metric names used in alert expressions or dashboard panels could be more easily linted against the manifest(s), flagging those that rely on no longer existing metric names (modulo recording rules).
  3. Users would be able to make informed decisions about alternative applications, based on how they are instrumented, and without needed to first deploy them.

Additional context

  • If some of the metrics are conditional (e.g. per-path latency metric), it would be tricky to generate them (would need to query the particular path), but it’s not a big deal if they are missing from the advertized manifest, because: (a) afaik conditional metrics are considered bad practice; (b) usually, it’s only the labels that carry the per-path info.

Prior art

@danielgblanco
Copy link
Contributor

Hi @sed-i, normally this time of proposal would come as a new project project in our community repo, or as an OTEP. Having said this, @svrnm has a draft for a project proposal on this same topic. I think it could meet the requirements above and integrate with our Registry.

@sed-i
Copy link
Author

sed-i commented Jan 6, 2025

Thanks @danielgblanco, @svrnm.
I'm also curious if this proposal overlaps with semantic conventions.
Iiuc, app devs would use weaver for that?

I'm new to otel so apologies about the ignorance 😅

@svrnm
Copy link
Member

svrnm commented Jan 7, 2025

Hey @sed-i,

the proposal does not overlap with semconv/weaver but will eventually be a consumer of that data. If you review the proposal and provide your feedback there that would be appreciated, since it helps to capture everything at one place. Note that this proposal is in draft state on purpose, since I do not have the bandwidth to execute it right now, so we are also looking for people to address this.

Thanks

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

No branches or pull requests

3 participants