Skip to content

fix(node-core): Recycle propagationContext for each request#19835

Open
Lms24 wants to merge 5 commits intodevelopfrom
lms/fix-node-core-recycle-traceid-tracing-disabled
Open

fix(node-core): Recycle propagationContext for each request#19835
Lms24 wants to merge 5 commits intodevelopfrom
lms/fix-node-core-recycle-traceid-tracing-disabled

Conversation

@Lms24
Copy link
Member

@Lms24 Lms24 commented Mar 17, 2026

This PR fixes a bug in our node-core httpServerIntegration (user-facing it's httpIntegration), which caused traceIds (or rather our propagationContext) to stay the same across requests. This would surface in SDK setups where tracing is not explicitly enabled (e.g. missing tracesSampleRate), causing caught errors across request to be associated with the same trace.

This PR now recycles the propagationContext on the current as well as isolation scope to ensure traces are isolated on a request level. Added node(-core) integration tests to demonstrate that traceIds are now scoped to requests, when tracing is enabled or disabled. Prior to this PR, the test for tracing being disabled failed.

Note: This should only have an effect on SDKs configured for tracing without spans (i.e. (and confusingly) no tracesSampleRate set), as for tracing with spans, we take the trace data from the active span directly. I added a test demonstrating this, just to be sure.

closes #19815
ref #17101

@Lms24 Lms24 changed the title fix(node-core): Recycle traceId per request when tracing is disabled fix(node-core): Recycle propagation context per request when tracing is disabled Mar 17, 2026
@Lms24 Lms24 changed the title fix(node-core): Recycle propagation context per request when tracing is disabled fix(node-core): Recycle propagation context for each request Mar 17, 2026
@Lms24 Lms24 changed the title fix(node-core): Recycle propagation context for each request fix(node-core): Recycle propagationContext for each request Mar 17, 2026
@github-actions
Copy link
Contributor

github-actions bot commented Mar 17, 2026

size-limit report 📦

⚠️ Warning: Base artifact is not the latest one, because the latest workflow run is not done yet. This may lead to incorrect results. Try to re-run all tests to get up to date results.

Path Size % Change Change
@sentry/browser 25.64 kB - -
@sentry/browser - with treeshaking flags 24.14 kB - -
@sentry/browser (incl. Tracing) 42.62 kB - -
@sentry/browser (incl. Tracing, Profiling) 47.28 kB - -
@sentry/browser (incl. Tracing, Replay) 81.42 kB - -
@sentry/browser (incl. Tracing, Replay) - with treeshaking flags 71 kB - -
@sentry/browser (incl. Tracing, Replay with Canvas) 86.12 kB - -
@sentry/browser (incl. Tracing, Replay, Feedback) 98.37 kB - -
@sentry/browser (incl. Feedback) 42.45 kB - -
@sentry/browser (incl. sendFeedback) 30.31 kB - -
@sentry/browser (incl. FeedbackAsync) 35.36 kB - -
@sentry/browser (incl. Metrics) 26.92 kB - -
@sentry/browser (incl. Logs) 27.07 kB - -
@sentry/browser (incl. Metrics & Logs) 27.74 kB - -
@sentry/react 27.39 kB - -
@sentry/react (incl. Tracing) 44.95 kB - -
@sentry/vue 30.08 kB - -
@sentry/vue (incl. Tracing) 44.48 kB - -
@sentry/svelte 25.66 kB - -
CDN Bundle 28.28 kB +0.04% +11 B 🔺
CDN Bundle (incl. Tracing) 43.51 kB +0.03% +10 B 🔺
CDN Bundle (incl. Logs, Metrics) 29.14 kB +0.05% +12 B 🔺
CDN Bundle (incl. Tracing, Logs, Metrics) 44.36 kB +0.03% +11 B 🔺
CDN Bundle (incl. Replay, Logs, Metrics) 68.21 kB +0.02% +12 B 🔺
CDN Bundle (incl. Tracing, Replay) 80.33 kB +0.02% +13 B 🔺
CDN Bundle (incl. Tracing, Replay, Logs, Metrics) 81.23 kB +0.02% +13 B 🔺
CDN Bundle (incl. Tracing, Replay, Feedback) 85.87 kB +0.02% +12 B 🔺
CDN Bundle (incl. Tracing, Replay, Feedback, Logs, Metrics) 86.77 kB +0.02% +12 B 🔺
CDN Bundle - uncompressed 82.62 kB +0.08% +59 B 🔺
CDN Bundle (incl. Tracing) - uncompressed 128.56 kB +0.05% +59 B 🔺
CDN Bundle (incl. Logs, Metrics) - uncompressed 85.49 kB +0.07% +59 B 🔺
CDN Bundle (incl. Tracing, Logs, Metrics) - uncompressed 131.43 kB +0.05% +59 B 🔺
CDN Bundle (incl. Replay, Logs, Metrics) - uncompressed 209.12 kB +0.03% +59 B 🔺
CDN Bundle (incl. Tracing, Replay) - uncompressed 245.41 kB +0.03% +59 B 🔺
CDN Bundle (incl. Tracing, Replay, Logs, Metrics) - uncompressed 248.26 kB +0.03% +59 B 🔺
CDN Bundle (incl. Tracing, Replay, Feedback) - uncompressed 258.32 kB +0.03% +59 B 🔺
CDN Bundle (incl. Tracing, Replay, Feedback, Logs, Metrics) - uncompressed 261.17 kB +0.03% +59 B 🔺
@sentry/nextjs (client) 47.37 kB - -
@sentry/sveltekit (client) 43.07 kB - -
@sentry/node-core 56.38 kB +0.09% +50 B 🔺
@sentry/node 173.19 kB +0.01% +3 B 🔺
@sentry/node - without tracing 96.37 kB +0.03% +27 B 🔺
@sentry/aws-serverless 113.37 kB +0.03% +32 B 🔺

View base workflow run

@github-actions
Copy link
Contributor

github-actions bot commented Mar 17, 2026

node-overhead report 🧳

Note: This is a synthetic benchmark with a minimal express app and does not necessarily reflect the real-world performance impact in an application.
⚠️ Warning: Base artifact is not the latest one, because the latest workflow run is not done yet. This may lead to incorrect results. Try to re-run all tests to get up to date results.

Scenario Requests/s % of Baseline Prev. Requests/s Change %
GET Baseline 8,897 - 8,614 +3%
GET With Sentry 1,710 19% 1,654 +3%
GET With Sentry (error only) 6,102 69% 5,933 +3%
POST Baseline 1,211 - 1,177 +3%
POST With Sentry 589 49% 553 +7%
POST With Sentry (error only) 1,072 89% 1,045 +3%
MYSQL Baseline 3,278 - 3,129 +5%
MYSQL With Sentry 502 15% 413 +22%
MYSQL With Sentry (error only) 2,695 82% 2,606 +3%

View base workflow run

@Lms24 Lms24 marked this pull request as ready for review March 17, 2026 14:23
@Lms24 Lms24 self-assigned this Mar 17, 2026
Copy link

@cursor cursor bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Cursor Bugbot has reviewed your changes and found 1 potential issue.

Fix All in Cursor

Bugbot Autofix is OFF. To automatically fix reported issues with cloud agents, enable autofix in the Cursor dashboard.

@Lms24 Lms24 requested review from a team, chargome and isaacs and removed request for a team March 17, 2026 14:33
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.

All errors are assigned to the same trace when tracing is disabled

1 participant