-
Notifications
You must be signed in to change notification settings - Fork 417
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
feat(propagation): add DD_TRACE_PROPAGATION_BEHAVIOR_EXTRACT to handle x-org propagation #11631
base: main
Are you sure you want to change the base?
Conversation
|
ddtrace/propagation/http.py
Outdated
# loop through all extract propagation styles | ||
else: | ||
contexts, styles_w_ctx = HTTPPropagator._extract_configured_contexts_avail(normalized_headers) | ||
if config._propagation_behavior_extract == _PROPAGATION_BEHAVIOR_CONTINUE: |
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.
BenchmarksBenchmark execution time: 2025-01-09 21:43:21 Comparing candidate commit 57b3239 in PR branch Found 0 performance improvements and 0 performance regressions! Performance is the same for 394 metrics, 2 unstable metrics. |
5d2512b
to
ef045c8
Compare
ddtrace/propagation/http.py
Outdated
context = propagator._extract(normalized_headers) | ||
rec_context = propagator._extract(normalized_headers) | ||
# if configured to restart, append our first context to the current context as a span link | ||
if rec_context: |
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.
Slightly changed behavior here so that the context never is set to None
. If this goes against spec I can change back.
…1723) This PR updates the `version_schema` in the `../pyproject.toml` file for the 2.18 release branch from `release-branch-semver` to `guess-next-dev`. This is to ensure that system tests work as intended with backports to this release branch. IMPORTANT: This PR needs to be merged before the first backport is created for 2.18.Otherwise, system tests will not work as expected. - [x] Reviewer check
…ncions [backport 2.18] (#11756) Backport a4f0e38 from #11752 to 2.18. This fix resolves an issue where AppSec was using a patched request and builtins functions, creating telemetry errors. ## Checklist - [x] PR author has checked that all the criteria below are met - The PR description includes an overview of the change - The PR description articulates the motivation for the change - The change includes tests OR the PR description describes a testing strategy - The PR description notes risks associated with the change, if any - Newly-added code is easy to change - The change follows the [library release note guidelines](https://ddtrace.readthedocs.io/en/stable/releasenotes.html) - The change includes or references documentation updates if necessary - Backport labels are set (if [applicable](https://ddtrace.readthedocs.io/en/latest/contributing.html#backporting)) ## Reviewer Checklist - [x] Reviewer has checked that all the criteria below are met - Title is accurate - All changes are related to the pull request's stated goal - Avoids breaking [API](https://ddtrace.readthedocs.io/en/stable/versioning.html#interfaces) changes - Testing strategy adequately addresses listed risks - Newly-added code is easy to change - Release note makes sense to a user of the library - If necessary, author has acknowledged and discussed the performance implications of this PR as reported in the benchmarks PR comment - Backport labels are set in a manner that is consistent with the [release branch maintenance policy](https://ddtrace.readthedocs.io/en/latest/contributing.html#backporting) Co-authored-by: Alberto Vara <[email protected]>
Co-authored-by: Christophe Papazian <[email protected]>
e21c4a3
to
1c4b37e
Compare
e2911cd
to
1568543
Compare
0fb3045
to
e1b10df
Compare
Datadog ReportBranch report: ✅ 0 Failed, 87 Passed, 1468 Skipped, 4m 3.25s Total duration (35m 36.02s time saved) |
@@ -20,6 +20,7 @@ jobs: | |||
with: | |||
persist-credentials: false | |||
repository: 'DataDog/system-tests' | |||
ref: 'zach.montoya/poc/propagation-behavior' |
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.
Going to remove these, just doing because struggling to build tracer locally
ddtrace/contrib/trace_utils.py
Outdated
@@ -577,7 +575,10 @@ def activate_distributed_headers(tracer, int_config=None, request_headers=None, | |||
# app = Flask(__name__) # Traced via Flask instrumentation | |||
# app = DDWSGIMiddleware(app) # Extra layer on top for WSGI | |||
current_context = tracer.current_trace_context() | |||
if current_context and current_context.trace_id == context.trace_id: | |||
|
|||
# We accept incoming contexts with only baggage, however if we |
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 accept contexts lacking trace_id to cover the following cases:
- Baggage only extraction
- DD_TRACE_PROPAGATION_BEHAVIOR_EXTRACT=restart which can result in span_link only extraction:
Unfortunately we can't compare baggages to tell if they're the same as the original headers, since the original incoming baggage could've been modified before we try to activate new headers in a nested framework. However, an alternative to tossing out an incoming baggage after we have an active context would be to merge them in some way, however I think that this is worse since it's possible customers may want to delete items from baggage.
I think the same applies to how span links could be modified as well.
5904cad
to
4436896
Compare
Ignore the failing system-test, it's just due to telemetry config differences since we added a new config. |
links = context._span_links if not parent else [] | ||
|
||
if trace_id: | ||
if trace_id or links: |
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.
Since we now count just span_links as a non-empty context, we need to make sure we initialize the span with them if they're available. This seems a little worrisome because we rely on the span init to make the right choices when we pass in None for some of these values. However, it does work.
Configuration: DD_TRACE_PROPAGATION_BEHAVIOR_EXTRACT
Values:
continue (default): The tracing library continues the trace from the incoming headers, if present. Also, incoming baggage is propagated.
restart: The tracing library always starts a new trace with a new trace-id. If there are distributed tracing headers, a span link will be added to reference the trace context. Also, incoming baggage is propagated.
ignore: The tracing library always starts a new trace with a new trace-id without creating any span links. Also, incoming baggage is dropped.
Note: We do not need to implement this at the moment because the workaround we have in place DD_TRACE_PROPAGATION_STYLE_EXTRACT=none performs this exact function of completely ignoring incoming trace context headers and baggage headers. If we receive feedback, we can add this new option that we maintain.
Result
✅ Head services: Customers can configure these services with the restart configuration so that they are always the root span, regardless of incoming distributed tracing headers.
✅ Internal services: By default, internal services will remain unchanged and continue to report complete traces to Datadog. If a user has configured an internal service with the restart configuration, this will lead to partial traces. Thankfully with Span Links we can easily direct the customer to the upstream trace (if it was sampled).
❌ Sometimes-head services: This solution does not solve for services that are sometimes head services and sometimes not. The best solution for these services is to set the restart configuration so that a new trace can begin and sampling priority can be recalculated, and in the case that this was not a head service then the upstream service can be found with a span link.
❌ Reentrant systems: This solution does not improve this scenario no matter how the reentrant service is configured. Under the continue configuration, the reentrant service is part of the same trace as the original root span but it is orphaned. Under the restart configuration, a new trace will be started and the span will be decorated with a span link containing the original trace-id but the contained span-id would not point to a span tracked in their Datadog organization.
Note: This contains a fix, allowing only baggage to be propagated.
Checklist
Reviewer Checklist