title | description | sidebar_order |
---|---|---|
Set Up Tracing |
Learn how to enable tracing in your app. |
4000 |
With tracing, Sentry automatically tracks your software performance across your application services, measuring metrics like throughput and latency, and displaying the impact of errors across multiple systems.
<PlatformCategorySection supported={["server", "serverless"]}> If you’re adopting Tracing in a high-throughput environment, we recommend testing prior to deployment to ensure that your service’s performance characteristics maintain expectations.
<PlatformSection notSupported={["javascript.deno", "javascript.bun", "javascript.cloudflare"]}> Sentry can integrate with OpenTelemetry. You can find more information about it here.
<PlatformContent supported={['javascript']}>
<PlatformSection supported={["javascript"]}> Enable tracing by configuring the sampling rate for transactions. Set the sample rate for your transactions by either:
<PlatformSection notSupported={["javascript"]}> Enable tracing by setting the sample rate for your transactions.
- You can establish a uniform sample rate for all transactions by setting the option in your SDK config to a number between
0
and1
. (For example, to send 20% of transactions, set to0.2
.) - For more granular control over sampling, you can set the sample rate based on the transaction itself and the context in which it's captured, by providing a function to the config option.
The two options are mutually exclusive. If both are set, will take precedence.
You can find more in-depth explanations and examples about sampling configuration in Configure Sampling.
Sentry captures distributed traces consisting of transactions and spans, which measure individual services and individual operations within those services, respectively. Learn more about our model in Distributed Tracing.
<PlatformSection supported={["javascript"]} notSupported={["javascript.cordova"]}>
Verify that tracing is working correctly by using our automatic instrumentation or by starting and finishing a transaction using custom instrumentation.
While you're testing, set to 1.0
, as that ensures that every transaction will be sent to Sentry. Once testing is complete, you may want to set a lower value, or switch to using to selectively sample and filter your transactions, based on contextual data.
If you leave your sample rate at 1.0
, a transaction will be sent every time a user loads a page or navigates within your app. Depending on the amount of traffic your application gets, this may mean a lot of transactions. If you have a high-load, backend application, you may want to consider setting a lower value, or switching to using to selectively sample and filter your transactions, based on contextual data.
<PlatformSection notSupported={["javascript.cordova"]}>
See Automatic Instrumentation to learn about all the things that the SDK automatically instruments for you.
You can also manually start spans to instrument specific parts of your code. This is useful when you want to measure the performance of a specific operation or function.
- Tracing APIs: Find information about APIs for custom tracing instrumentation
- Instrumentation: Find information about manual instrumentation with the Sentry SDK
- Sending Span Metrics: Learn how to capture metrics on your spans