-
Notifications
You must be signed in to change notification settings - Fork 896
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
Metric Exemplars SDK Specification #1828
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
FYI I have been working on trace sampling lately, and there is a lot of alignment between that work and this work. I have made claims that we can use weighted sampling to implement a hard rate limit on spans inside a tail sampler, and by extension I claim to know how to do the same for histogram exemplars. For a histogram aggregator outputting high-resolution histogram buckets you might not want one exemplar per bucket, and with weighted sampling we can produce a fixed number (i.e., using a reservoir) of exemplars with an equal expected number of spans per bucket. This simple approach uses two passes, documented in the README of the https://github.com/lightstep/varopt repository. The more complicated approach can do this approximately in a single pass, which I also discussed briefly in today's Sampling SIG. See this draft. I will elaborate on this in a prototype exemplar reservoir tail sampler based on Varopt. |
@jmacd I agree I think we can do way better than status quo, especially for high-fidelity histograms. I re-tweaked the wording to leave room for an exemplar reservoir sampling specification when those land. |
This PR was marked stale due to lack of activity. It will be closed in 7 days. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, I've left some minor comments.
specification/metrics/sdk.md
Outdated
The "offer" method SHOULD accept measurements, including: | ||
|
||
- value | ||
- `Attributes` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same comment as above
specification/metrics/sdk.md
Outdated
@@ -128,6 +128,8 @@ are the inputs: | |||
applies to [synchronous Instruments](./api.md#synchronous-instrument). | |||
* The `aggregation` (optional) to be used. If not provided, a default | |||
aggregation will be applied by the SDK. The default aggregation is a TODO. | |||
* The `exemplar_reservoir` to use for storing exemplars. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should be marked optional right?
Co-authored-by: Reiley Yang <[email protected]>
Co-authored-by: Reiley Yang <[email protected]>
Co-authored-by: Reiley Yang <[email protected]>
Co-authored-by: Reiley Yang <[email protected]>
Co-authored-by: Reiley Yang <[email protected]>
Co-authored-by: Aaron Abbott <[email protected]>
* First cut at exemplar spec. * Update exemplar specification. * Remove the word parent Co-authored-by: Reiley Yang <[email protected]> * Update specification/metrics/sdk.md Co-authored-by: Reiley Yang <[email protected]> * Update specification/metrics/sdk.md Co-authored-by: Reiley Yang <[email protected]> * Update specification/metrics/sdk.md Co-authored-by: Reiley Yang <[email protected]> * Update specification/metrics/sdk.md Co-authored-by: Reiley Yang <[email protected]> * Update specification/metrics/sdk.md Co-authored-by: Aaron Abbott <[email protected]> * Fixes from review. * Clarify a confusing paragraph. Co-authored-by: Reiley Yang <[email protected]> Co-authored-by: Aaron Abbott <[email protected]>
Fixes #1797
Changes
Add Exemplar specification and customization to the metrics specification.
Related issues #1260 #617
Related oteps #113
Notes