React Error and Performance Monitoring

Actionable insights to resolve React performance bottlenecks and errors. Improve your monitoring workflow with a full view of releases so you can mark React errors as resolved and prioritize live issues.

Getting Started is Simple

Grab the Sentry React SDK:

Click to Copy
npm install @sentry/react

Configure your DSN:

Click to Copy
import React from "react"; import ReactDOM from "react-dom"; import * as Sentry from "@sentry/react"; import App from "./App"; Sentry.init({ dsn: "https://<key>@sentry.io/<project>", // This enables automatic instrumentation (highly recommended) // If you only want to use custom instrumentation: // * Remove the BrowserTracing integration // * add Sentry.addTracingExtensions() above your Sentry.init() call integrations: [ Sentry.browserTracingIntegration(), // Or, if you are using react router, use the appropriate integration // See docs for support for different versions of react router // https://docs.sentry.io/platforms/javascript/guides/react/configuration/integrations/react-router/ Sentry.reactRouterV6BrowserTracingIntegration({ useEffect: React.useEffect, useLocation, useNavigationType, createRoutesFromChildren, matchRoutes, }), ], // For finer control of sent transactions you can adjust this value, or // use tracesSampler tracesSampleRate: 1.0, // Set tracePropagationTargets to control for which URLs distributed tracing should be enabled tracePropagationTargets: ['localhost', /^https://yourserver.io/api/], }); ReactDOM.render(<App />, document.getElementById("root"));

Check our documentation for the latest instructions.

See all platforms

How to install the React SDK

React Performance Monitoring

Quickly identify performance issues and view full end-to-end distributed trace to see the exact poor-performing API call and surface any related React errors. Improve React performance with max efficiency, not max effort.

React Error Monitoring With Complete Stack Traces

See the error and React stack trace previously only visible in your user’s debug console. Apply source maps automatically to convert minified, compiled, or transpiled code back to its original form. Keep your React source maps private by uploading them directly to Sentry.

Issues, replayed

Get to the root cause of an error or latency issue faster with context like DOM events, console logs, and network calls within one visual replay on your web application.

Check out Session Replay

Fill In The Blanks About React Errors

See what the app was doing when the React error occurred: user interactions, AJAX requests, console log messages, and more. Learn in which version a bug first appeared, merge duplicates, and know if things regress in a future release

“By correlating Sentry issues to our dev cycle, we can spot where problems begin and how to fix the source.”

Jim Redmond
Sr. System Engineer, Bitbucket

See The Full Picture Of Any React Exception

Record environment and usage details so you can recreate bugs down to the browser version, OS, and query parameters specific to your app.

Sentry’s tag distribution graph makes it easy to isolate and prioritize any React error by seeing how often it occurs in context.

Find answers to key questions: How actionable is this error?Was the bug browser or OS specific?

You can’t afford to put JavaScript monitoring on the backburner.

Even a one-second delay in loading results in a 7% reduction in conversions.

Forty percent of customers abandon a website that takes longer than three seconds to load.

The average cost of downtime is $5,600 per minute — or $300,000 per hour.

FAQs

Traditional logging provides you with a trail of events. Some of those events are errors, but many times they’re simply informational. Sentry is fundamentally different because we focus on exceptions, or in other words, we capture application crashes. We discuss in more detail here and on our blog.

Sentry supports every major frontend language, framework, and library. You can browse each of them here.

You can get started for free. Pricing depends on the number of monthly events, transactions, and attachments that you send Sentry. For more details, visit our pricing page.

Sentry doesn’t impact a web site’s performance.

If you look at the configuration options for when you initialize Sentry in your code, you’ll see there’s nothing regarding minimizing its impact on your app’s performance. This is because our team of SDK engineers already developed Sentry with this in mind.

Sentry is a listener/handler for errors that asynchronously sends out the error/event to Sentry.io. This is non-blocking. The error/event only goes out if this is an error.

Global handlers have almost no impact as well, as they are native APIs provided by the browsers.

A better experience for your users. An easier life for your developers.