Official Sentry SDK for AWS Lambda
Links
General
This package is a wrapper around @sentry/node, with added functionality related to AWS Lambda. All
methods available in @sentry/node can be imported from @sentry/aws-serverless.
Automatic Setup
To use this SDK with an automatic setup, set the following environment variables in your Lambda function configuration:
NODE_OPTIONS="--import @sentry/aws-serverless/awslambda-auto"
SENTRY_DSN="__DSN__"
SENTRY_TRACES_SAMPLE_RATE="1.0"
Manual Setup
Alternatively, to further customize the SDK setup, you can also manually initialize the SDK in your lambda function. The benefit of this installation method is that you can fully customize your Sentry SDK setup in a Sentry.init call.
Create a new file, for example instrument.js to initialize the SDK:
import * as Sentry from '@sentry/aws-serverless';
Sentry.init({
dsn: '__DSN__',
sendDefaultPii: true,
tracesSampleRate: 1.0,
});
And then load the SDK before your function starts by importing the instrument.js file via a NODE_OPTIONS environment variable:
NODE_OPTIONS="--import ./instrument.js"
Verify
export const handler = async (event, context) => {
throw new Error('oh, hello there!');
};
export const handler = (event, context, callback) => {
throw new Error('oh, hello there!');
};
Integrate Sentry using the Sentry Lambda layer
Another much simpler way to integrate Sentry to your AWS Lambda function is to add the official layer.
- Choose Layers -> Add Layer.
- Specify an ARN:
arn:aws:lambda:us-west-1:943013980633:layer:SentryNodeServerlessSDKv10:19. Get the latest ARN from the docs.
- Go to Environment variables and add:
NODE_OPTIONS: --import @sentry/aws-serverless/awslambda-auto.
SENTRY_DSN: your dsn.
SENTRY_TRACES_SAMPLE_RATE: a number between 0 and 1 representing the chance a transaction is sent to Sentry. For
more information, see
docs.