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

Add JaegerRemoteSampler spec #2222

Merged
merged 4 commits into from
Jan 10, 2022

Conversation

pavolloffay
Copy link
Member

@pavolloffay pavolloffay requested review from a team December 14, 2021 14:31
specification/trace/jaeger-remote-sampler.md Outdated Show resolved Hide resolved
specification/trace/jaeger-remote-sampler.md Outdated Show resolved Hide resolved
specification/trace/jaeger-remote-sampler.md Outdated Show resolved Hide resolved
@willarmiros
Copy link
Contributor

cc @bhautikpip as well

@william-tran
Copy link

There's discussion in the Otel Sampling SIG about aligning on an OTel native remote sampler, and as a user I'd still want to see that happen as I'm looking for features like matching Samplers to any attributes instead of just service and operation name. But I see this as a way to help Jaeger users transition to OTel; while addressing the need to evolve remote sampling to enable more fine grained control can continue to happen.

specification/trace/sdk.md Outdated Show resolved Hide resolved
@pavolloffay
Copy link
Member Author

'd still want to see that happen as I'm looking for features like matching Samplers to any attributes instead of just service and operation name. But I see this as a way to help Jaeger users transition to OTel; while addressing the need to evolve remote sampling to enable more fine grained control can continue to happen.

+1. This effort is mostly to enable migration. I do agree that more generic remote sampling is needed in the long run.

specification/trace/sdk.md Outdated Show resolved Hide resolved
@github-actions
Copy link

This PR was marked stale due to lack of activity. It will be closed in 7 days.

@github-actions github-actions bot added the Stale label Dec 29, 2021
@pavolloffay
Copy link
Member Author

Can somebody merge the PR? The GH actions bot wants to close it

@yurishkuro yurishkuro enabled auto-merge (squash) January 3, 2022 15:24
@yurishkuro yurishkuro removed the Stale label Jan 3, 2022
@yurishkuro
Copy link
Member

@pavolloffay would merging it introduce a contradiction since OTEL has no rate limiting sampler?

@yurishkuro yurishkuro disabled auto-merge January 3, 2022 15:27
@jmacd
Copy link
Contributor

jmacd commented Jan 4, 2022

@pavolloffay would merging it introduce a contradiction since OTEL has no rate limiting sampler?

I don't mind this contradiction. In the terminology of #2047, RateLimited is some sort of non-probability Sampler and not very specific. I understand that often RateLimited is implemented by a LeakyBucket sampler, which has 2 (?) parameters. Perhaps replace "RateLimited" by "rate-limited" and file an issue to define the LeakyBucket rate-limited sampler in a future iteration?

@yurishkuro
Copy link
Member

Perhaps replace "RateLimited" by "rate-limited"

Seems reasonable. I do think implementing rate limiter will be needed, especially to guarantee minimal level of sampling of rare endpoints, so this would be an added requirement for SDKs that want to support Jaeger's remote sampling policy format.

often RateLimited is implemented by a LeakyBucket sampler, which has 2 (?) parameters

the algorithm has two parameters, but the sampler usually has only one, the rate of traces / sec sampled (could be fractional).

@carlosalberto
Copy link
Contributor

Left a non-blocking comment, otherwise LGTM

@anuraaga
Copy link
Contributor

anuraaga commented Jan 5, 2022

Perhaps replace "RateLimited" by "rate-limited" and file an issue to define the LeakyBucket rate-limited sampler in a future iteration?

#1769 is the issue for a rate limiting sampler. My impression from the thread is it was rejected for addition to OTel since it doesn't support probabilistic sampling 😃

@jmacd
Copy link
Contributor

jmacd commented Jan 5, 2022

My impression from the thread is it was rejected for addition to OTel since it doesn't support probabilistic sampling

Right. Probability sampling is preferable to non-probability sampling. Speaking as a vendor, we are not interested in receiving sampled spans without being able to count them. #2047 specifies how to mix these two kinds of Sampler, and I consider this to admit specifications for non-probability samplers when it merges. When that happens, the user that @yurishkuro describes, who wants to combine probability sampling with a minimum-rate could have options:

(a) A leaky bucket sampler (for minimum-rate sampling) composed with a probability sampler (for Span-to-metrics)
(a) An adaptive sampler that adjusts a simple probability sampler to maintain a soft rate limit, in which case all spans are countable but the rate limit is not guaranteed.

Given these choices, I'd choose (b) and I expect the complexity of the adaptive logic to be less than the complexity of the leaky bucket algorithm. This is why I suggested we write "rate-limited" instead of naming a specific algorithm, because naming a specific algorithm requires, well, specifying it. Do you want to write the specification for LeakyBucket? I'd prefer to write the adaptive sampler specification.

@carlosalberto
Copy link
Contributor

@anuraaga @jmacd should we follow the discussion either in #1769 and merge this? Or have a blocking request?

@carlosalberto
Copy link
Contributor

@pavolloffay This PR needs to be updated ;(

@pavolloffay pavolloffay force-pushed the jaeger-remote-sampler-spec branch from cc73430 to 65e3ad5 Compare January 7, 2022 09:30
Signed-off-by: Pavol Loffay <[email protected]>
Signed-off-by: Pavol Loffay <[email protected]>
@pavolloffay pavolloffay force-pushed the jaeger-remote-sampler-spec branch from 65e3ad5 to 5e1652d Compare January 7, 2022 09:38
@pavolloffay
Copy link
Member Author

@carlosalberto PR rebased and renamed RateLimitting to rate-limited per @jmacd request.

@jmacd jmacd enabled auto-merge (squash) January 10, 2022 18:58
@jmacd jmacd merged commit bda9a7e into open-telemetry:main Jan 10, 2022
carlosalberto pushed a commit to carlosalberto/opentelemetry-specification that referenced this pull request Oct 31, 2024
* Add JaegerRemoteSampler spec

Signed-off-by: Pavol Loffay <[email protected]>

* rename to rate-limited

Signed-off-by: Pavol Loffay <[email protected]>

Co-authored-by: Joshua MacDonald <[email protected]>
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

Successfully merging this pull request may close these issues.

10 participants