-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
Refactor the probabilistic sampler processor; add FailClosed configuration, prepare for OTEP 235 support #31946
Conversation
…tor-contrib into jmacd/tvaluesampler
…tor-contrib into jmacd/tvaluesampler
…ype similar to configcomprsesion.CompressionType
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.
I like this a lot, and I'm eager to see this merged. I would like to request one change before that, though: could you add a benchmark that exercised the top-level consumer functions? I suspect this here will bring performance improvements, but there are a few checks in the hot path that might need some attention.
processor/probabilisticsamplerprocessor/tracesprocessor_test.go
Outdated
Show resolved
Hide resolved
processor/probabilisticsamplerprocessor/tracesprocessor_test.go
Outdated
Show resolved
Hide resolved
processor/probabilisticsamplerprocessor/tracesprocessor_test.go
Outdated
Show resolved
Hide resolved
…tor-contrib into jmacd/bigrefactor
…tor-contrib into jmacd/bigrefactor
…tor-contrib into jmacd/bigrefactor
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 is so much better now; easier to read and understand. I had a couple of notes but no blockers.
One question that I'd like to be sure of because I've recently been bitten by this problem -- with FailClosed being a boolean that defaults to true, can the config system tell the difference between a config file that doesn't specify FailClosed, and one where FailClosed is set to false?
In logs pipelines, when the priority attribute has value 0, the | ||
configured probability will by modified to 0%, and the item will not | ||
pass the sampler. Otherwise, the logs sampling priority attribute is | ||
interpreted as a percentage, with values >= 100 equal to 100% |
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.
We could unify the solutions by varying behavior according to the type of the attribute. If numeric, it's the priority, and if a string, it's the name of the numeric attribute containing the priority.
Personally, I'd prefer to choose one for the long term, something like:
- State that the current traces behavior for
sampling.priority
is deprecated and that the logs behavior is desired. - For some period of time (probably a long time) state that when traces are configured with a numeric value for
sampling.priority
, it is interpreted as the configured probability, but that a string value will be treated as the name of the attribute to be used for priority.
It would be just as valid to do it the other way, if we preferred less configuration.
Co-authored-by: Kent Quirk <kentquirk@gmail.com>
In logs pipelines, when the priority attribute has value 0, the | ||
configured probability will by modified to 0%, and the item will not | ||
pass the sampler. Otherwise, the logs sampling priority attribute is | ||
interpreted as a percentage, with values >= 100 equal to 100% |
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.
I think this might be the perfect opportunity for this change, but not necessarily part of this PR.
## Hashing | ||
- `sampling_percentage` (32-bit floating point, required): Percentage at which items are sampled; >= 100 samples all items, 0 rejects all items. | ||
- `hash_seed` (32-bit unsigned integer, optional, default = 0): An integer used to compute the hash algorithm. Note that all collectors for a given tier (e.g. behind the same load balancer) should have the same hash_seed. | ||
- `fail_closed` (boolean, optional, default = true): Whether to reject items with sampling-related errors. |
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.
Sounds good!
…rt OTEP 235) (#31894) **Description:** Creates new sampler modes named "equalizing" and "proportional". Preserves existing functionality under the mode named "hash_seed". Fixes #31918 This is the final step in a sequence, the whole of this work was factored into 3+ PRs, including the new `pkg/sampling` and the previous step, #31946. The two new Sampler modes enable mixing OTel sampling SDKs with Collectors in a consistent way. The existing hash_seed mode is also a consistent sampling mode, which makes it possible to have a 1:1 mapping between its decisions and the OTEP 235 randomness and threshold values. Specifically, the 14-bit hash value and sampling probability are mapped into 56-bit R-value and T-value encodings, so that all sampling decisions in all modes include threshold information. This implements the semantic conventions of open-telemetry/semantic-conventions#793, namely the `sampling.randomness` and `sampling.threshold` attributes used for logs where there is no tracestate. The default sampling mode remains HashSeed. We consider a future change of default to Proportional to be desirable, because: 1. Sampling probability is the same, only the hashing algorithm changes 2. Proportional respects and preserves information about earlier sampling decisions, which HashSeed can't do, so it has greater interoperability with OTel SDKs which may also adopt OTEP 235 samplers. **Link to tracking Issue:** Draft for open-telemetry/opentelemetry-specification#3602. Previously #24811, see also open-telemetry/oteps#235 Part of #29738 **Testing:** New testing has been added. **Documentation:** ✅ --------- Co-authored-by: Juraci Paixão Kröhling <juraci.github@kroehling.de>
Description:
Refactors the probabilistic sampling processor to prepare it for more OTEP 235 support.
This clarifies existing inconsistencies between tracing and logging samplers, see the updated README. The tracing priority mechanism applies a 0% or 100% sampling override (e.g., "1" implies 100% sampling), whereas the logging sampling priority mechanism supports variable-probability override (e.g., "1" implies 1% sampling).
This pins down cases where no randomness is available, and organizes the code to improve readability. A new type called
randomnessNamer
carries the randomness information (from the sampling pacakge) and a name of the policy that derived it. When sampling priority causes the effective sampling probability to change, the value "sampling.priority" replaces the source of randomness, which is currently limited to "trace_id_hash" or the name of the randomess-source attribute, for logs.While working on #31894, I discovered that some inputs fall through to the hash function with zero bytes of input randomness. The hash function, computed on an empty input (for logs) or on 16 bytes of zeros (which OTel calls an invalid trace ID), would produce a fixed random value. So, for example, when logs are sampled and there is no TraceID and there is no randomness attribute value, the result will be sampled at approximately 82.9% and above.
In the refactored code, an error is returned when there is no input randomness. A new boolean configuration field determines the outcome when there is an error extracting randomness from an item of telemetry. By default, items of telemetry with errors will not pass through the sampler. When
FailClosed
is set to false, items of telemetry with errors will pass through the sampler.The original hash function, which uses 14 bits of information, is structured as an "acceptance threshold", ultimately the test for sampling translated into a positive decision when
Randomness < AcceptThreshold
. In the OTEP 235 scheme, thresholds are rejection thresholds--this PR modifies the original 14-bit accept threshold into a 56-bit reject threshold, using Threshold and Randomness types from the sampling package. Reframed in this way, in the subsequent PR (i.e., #31894) the effective sampling probability will be seamlessly conveyed using OTEP 235 semantic conventions.Note, both traces and logs processors are now reduced to a function like this:
which is a generic function that handles the common logic on a per-item basis and ends in a single metric event. This structure makes it clear how traces and logs are processed differently and have different prioritization schemes, currently. This structure also makes it easy to introduce new sampler modes, as shown in #31894. After this and #31940 merge, the changes in #31894 will be relatively simple to review as the third part in a series.
Link to tracking Issue:
Depends on #31940.
Part of #31918.
Testing: Added. Existing tests already cover the exact random behavior of the current hashing mechanism. Even more testing will be introduced with the last step of this series. Note that #32360 is added ahead of this test to ensure refactoring does not change results.
Documentation: Added.