Skip to content

Combined CDN bundle including core SDK, multiplexed transport and module-metadata integration #17309

@Laura-Arcidiacono

Description

@Laura-Arcidiacono

Problem Statement

Currently, we integrate Sentry into our web application solely through CDN scripts (not through NPM installation), loading the bundle.min.js (core SDK).
We want to enable error routing for the microfrontend, but there is no bundle to do so, and that forces us to load two additional files:
1. multiplexedtransport.min.js
2. modulemetadata.min.js

This approach works, but introduces:
• Performance concerns: three HTTP requests
• Version-management overhead
• HTML verbosity: extra tags in every page template

Solution Brainstorm

Publish an additional CDN artifact that internally includes:

  • the core bundle.min.js
  • transports/multiplexedtransport.js
  • integrations/modulemetadataintegration.js

All in one file, exposing Sentry.makeMultiplexedTransport() and Sentry.moduleMetadataIntegration() on the global Sentry object.

Benefits:

  • Single download: one small script to fetch in parallel, reducing latency and round-trips.
  • Slim footprint: the bundle should include only the core SDK plus the two micro-frontend features, keeping its gzipped size as small as possible so as not to impact page performance.
  • Simplified integration: customers can add a single <script src="…/sentry.microfrontends.min.js"> and call Sentry.init({ ..., integrations: [Sentry.moduleMetadataIntegration()], transport: Sentry.makeMultiplexedTransport(...) }) without worrying about additional URLs.
  • Cache efficiency: one bundle means better long-term caching and fewer cache invalidations.
  • Lower maintenance: teams relying purely on CDN loads (no npm) avoid manual sync of multiple file versions.
  • The multiplexed transport and module metadata features could be lazy-loaded, so that they are available in the Sentry Object only once an error occurs.

Product Area

Performance

Metadata

Metadata

Assignees

No one assigned

    Projects

    Status

    No status

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions