Skip to content

ref(node): Streamline mysql2 instrumentation#21509

Open
logaretm wants to merge 1 commit into
developfrom
awad/js-2391-streamline-opentelemetryinstrumentation-mysql2
Open

ref(node): Streamline mysql2 instrumentation#21509
logaretm wants to merge 1 commit into
developfrom
awad/js-2391-streamline-opentelemetryinstrumentation-mysql2

Conversation

@logaretm

@logaretm logaretm commented Jun 12, 2026

Copy link
Copy Markdown
Member

Streamlines the vendored mysql2 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).

Notes

Blockers for startSpan*

mysql2 ends its span manually since completion fires via stream events/callbacks after the sync wrapper returns, which startSpan's auto-end misses. Worse, the returned Query is thenable but not a real Promise with a .then that throws, so startSpan/startSpanManual would throw on every query. startInactiveSpan leaves the Query untouched.

Semantic Conventions Attributes

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

Modernizing the semconv is deferred as a separate, breaking change.

Fixes #20739

Refactors the vendored mysql2 instrumentation to use Sentry's span APIs
instead of the OpenTelemetry tracing API, and removes the config paths
that are dead in Sentry's context.

- Replace `tracer.startSpan` with `startInactiveSpan`. mysql2's `query`/
  `execute` complete via stream events or a patched callback that fire
  after the synchronous wrapper returns, so the span must outlive a sync
  scope and is ended manually. `startSpan`/`startSpanManual` are unusable
  here: the returned `Query` is thenable-but-not-a-Promise, and its core
  `.then` is a trap that throws, so the promise-probing in
  `handleCallbackErrors` would throw on every query.
- Bake the origin in via `SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN` instead of an
  `index.ts` responseHook.
- Drop the `OTEL_SEMCONV_STABILITY_OPT_IN` dual-emission and the unused
  `responseHook`, query masking, and SQL-commenter config. The
  integration only ever passed the origin responseHook, so these were
  unreachable. mysql2 spans now always emit the legacy semconv attributes
  (`db.system`, `db.statement`, `net.peer.*`); op is derived downstream.
- Drop the blanket eslint-disable, type the module exports shallowly.
- Add unit tests against a fake connection and assert origin/db.statement
  in the integration suite.

Fixes #20739
@linear-code

linear-code Bot commented Jun 12, 2026

Copy link
Copy Markdown

JS-2391

@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 130.35 kB -0.14% -170 B 🔽
@sentry/node - without tracing 74.11 kB - -
@sentry/aws-serverless 86.29 kB - -
@sentry/cloudflare (withSentry) - minified 173.69 kB - -
@sentry/cloudflare (withSentry) 433.85 kB - -

View base workflow run

@logaretm logaretm marked this pull request as ready for review June 12, 2026 16:24
@logaretm logaretm requested a review from a team as a code owner June 12, 2026 16:24
@logaretm logaretm requested review from JPeer264, andreiborza, mydea and nicohrubec and removed request for a team June 12, 2026 16:24
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.

Streamline @opentelemetry/instrumentation-mysql2

1 participant