Skip to content

ref(node): Streamline ioredis instrumentation#21560

Merged
logaretm merged 1 commit into
developfrom
awad/js-2383-streamline-opentelemetryinstrumentation-ioredis
Jun 15, 2026
Merged

ref(node): Streamline ioredis instrumentation#21560
logaretm merged 1 commit into
developfrom
awad/js-2383-streamline-opentelemetryinstrumentation-ioredis

Conversation

@logaretm

@logaretm logaretm commented Jun 15, 2026

Copy link
Copy Markdown
Member

Streamlines the vendored ioredis instrumentation to use Sentry's span APIs instead of the OpenTelemetry tracing APIs.

I removed the fake tests, added test cases to the integration tests, and dropped any unreachable code.

Streamlines the vendored `ioredis` instrumentation to use Sentry's span
APIs instead of the OpenTelemetry tracing API, and removes the code
paths that are dead in Sentry's context.

Mirrors the approach in #21481 (mongoose) and #21509 (mysql2).

### Notes

#### Blockers for `startSpan*`

ioredis ends its span manually since completion fires via the patched
`cmd.resolve`/`cmd.reject` (and the `connect` promise) after the sync
wrapper returns, which `startSpan`'s auto-end misses. `startInactiveSpan`
leaves the return value untouched (no thenable probing).

#### Semantic Conventions Attributes

Dropping the `OTEL_SEMCONV_STABILITY_OPT_IN` path means ioredis spans now
**always** emit the legacy semantic-convention attributes (`db.system`,
`db.statement`, `db.connection_string`, `net.peer.*`).

Modernizing the semconv is deferred as a separate, breaking change.
@linear-code

linear-code Bot commented Jun 15, 2026

Copy link
Copy Markdown

JS-2383

@github-actions

Copy link
Copy Markdown
Contributor

size-limit report 📦

Path Size % Change Change
@sentry/browser 27.4 kB - -
@sentry/browser - with treeshaking flags 25.84 kB - -
@sentry/browser (incl. Tracing) 45.7 kB - -
@sentry/browser (incl. Tracing + Span Streaming) 47.94 kB - -
@sentry/browser (incl. Tracing, Profiling) 50.5 kB - -
@sentry/browser (incl. Tracing, Replay) 84.92 kB - -
@sentry/browser (incl. Tracing, Replay) - with treeshaking flags 74.53 kB - -
@sentry/browser (incl. Tracing, Replay with Canvas) 89.61 kB - -
@sentry/browser (incl. Tracing, Replay, Feedback) 102.3 kB - -
@sentry/browser (incl. Feedback) 44.56 kB - -
@sentry/browser (incl. sendFeedback) 32.2 kB - -
@sentry/browser (incl. FeedbackAsync) 37.31 kB - -
@sentry/browser (incl. Metrics) 28.47 kB - -
@sentry/browser (incl. Logs) 28.71 kB - -
@sentry/browser (incl. Metrics & Logs) 29.4 kB - -
@sentry/react 29.2 kB - -
@sentry/react (incl. Tracing) 48 kB - -
@sentry/vue 32.42 kB - -
@sentry/vue (incl. Tracing) 47.59 kB - -
@sentry/svelte 27.42 kB - -
CDN Bundle 29.79 kB - -
CDN Bundle (incl. Tracing) 48.2 kB - -
CDN Bundle (incl. Logs, Metrics) 31.33 kB - -
CDN Bundle (incl. Tracing, Logs, Metrics) 49.49 kB - -
CDN Bundle (incl. Replay, Logs, Metrics) 70.62 kB - -
CDN Bundle (incl. Tracing, Replay) 85.52 kB - -
CDN Bundle (incl. Tracing, Replay, Logs, Metrics) 86.77 kB - -
CDN Bundle (incl. Tracing, Replay, Feedback) 91.37 kB - -
CDN Bundle (incl. Tracing, Replay, Feedback, Logs, Metrics) 92.62 kB - -
CDN Bundle - uncompressed 88.59 kB - -
CDN Bundle (incl. Tracing) - uncompressed 145.8 kB - -
CDN Bundle (incl. Logs, Metrics) - uncompressed 93.29 kB - -
CDN Bundle (incl. Tracing, Logs, Metrics) - uncompressed 149.77 kB - -
CDN Bundle (incl. Replay, Logs, Metrics) - uncompressed 218.12 kB - -
CDN Bundle (incl. Tracing, Replay) - uncompressed 264.67 kB - -
CDN Bundle (incl. Tracing, Replay, Logs, Metrics) - uncompressed 268.63 kB - -
CDN Bundle (incl. Tracing, Replay, Feedback) - uncompressed 278.37 kB - -
CDN Bundle (incl. Tracing, Replay, Feedback, Logs, Metrics) - uncompressed 282.31 kB - -
@sentry/nextjs (client) 50.45 kB - -
@sentry/sveltekit (client) 46.12 kB - -
@sentry/core/server 76.08 kB - -
@sentry/core/browser 63.22 kB - -
@sentry/node-core 61.72 kB - -
@sentry/node 129.28 kB -0.18% -226 B 🔽
@sentry/node - without tracing 74.1 kB - -
@sentry/aws-serverless 86.35 kB - -
@sentry/cloudflare (withSentry) - minified 174.19 kB - -
@sentry/cloudflare (withSentry) 435.41 kB - -

View base workflow run

@logaretm logaretm marked this pull request as ready for review June 15, 2026 20:07
@logaretm logaretm requested a review from a team as a code owner June 15, 2026 20:07
@logaretm logaretm requested review from JPeer264, andreiborza, mydea and nicohrubec and removed request for a team June 15, 2026 20:07
@logaretm logaretm merged commit aa9c09d into develop Jun 15, 2026
533 of 535 checks passed
@logaretm logaretm deleted the awad/js-2383-streamline-opentelemetryinstrumentation-ioredis branch June 15, 2026 20:42
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.

2 participants