Description
In #10540 we explored refactoring the serverless
package for v8, and we found some more structural issues that needed to be solved. This was further expanded with #10561.
This is a brief proposal for the changes I think the serverless package should take.
Current State
Right now @sentry/serverless
:
- re-exports everything from
@sentry/node
(aka@sentry/node-experimental
) under main package exports
import { captureException } from '@sentry/serverless';
- Exports 4 functions
init
,getDefaultIntegrations
,wrapHandler
,tryPatchHandler
and re-exports all of@sentry/node
underAWSLambda
namespace
import { AWSLambda } from '@sentry/serverless';
AWSLambda.init(...);
AWSLambda.wrapHandler(...);
AWSLambda.captureException(...);
- Exports 5 functions
init
,getDefaultIntegrations
,wrapCloudEventHandler
,wrapEventFunction
,wrapHttpFunction
under theGCPFunction
namespace
import { GCPFunction } from '@sentry/serverless';
GCPFunction.init(...);
GCPFunction.wrapCloudEventHandler(...);
There is some logic in awslambda-auto.ts
that is used for the lambda layer.
The main export also contains awsServicesIntegration
export. There is a googleCloudGrpcIntegration
and googleCloudHttpIntegration
that exists in the package, but is not exported 😢.
Problem
- Namespace exports like
AWSLambda
andGCPFunction
are not treeshakable, and bundle size really matters for serverless. This is not that bad forGCPFunction
, but givenAWSLambda
re-exports all of the node sdk, that means anyone usingAWSLambda
and bundling pulls in the entire node sdk! - It is very confusing to have three different
init
exported from the same package, each with their own behaviours (node init, aws init, gcp init) - AWS and GCP code share nothing in common with each other (the utils file in serverless is only used by gcp related code), and the structure is confusing for maintainers.
Solution
I propose we split @sentry/serverless
into two packages, @sentry/aws
and @sentry/google-cloud
. This means we only export a single init
, and for users the onboarding becomes way easier. In the future we can easily add support for @sentry/azure
or similar! This makes sure we can optimize for that specific serverless package.
We have two options:
- Make the change in v7 and deprecate the
@sentry/serverless
package (easier upgrade path) - Just split the packages up in v8 and make the breaking change for every serverless sdk user to switch to using either
@sentry/aws
or@sentry/google-cloud
(lambda layer users will not be impacted in anyway.
The biggest change is to change package name, but we aren't breaking any of the top level exports so migration shouldn't be too bad. Lambda functions are also small, so I can't see it being too much work to go through people's codebase and change things.
Addendum
In #10561 I explored using subpath exports as an alternative to new packages. I'm happier with the separate packages (more accurate download counts too!), but we can change the proposal if sentiments have changed.
Work
### Tasks
- [x] https://github.com/getsentry/sentry-javascript/pull/10993
- [x] remove all google cloud logic from `@sentry/serverless`
- [ ] https://github.com/getsentry/sentry-javascript/pull/11052
- [ ] https://github.com/getsentry/sentry-javascript/pull/11065
- [ ] https://github.com/getsentry/sentry-javascript/issues/11066
- [x] Update the path for the env var that Sentry sets in peoples lambdas https://github.com/getsentry/sentry/blob/b5f2368068033e3a32b049cba4ff2d7f20612f48/src/sentry/integrations/aws_lambda/utils.py#L242
- [ ] https://github.com/getsentry/sentry/pull/70137
### After Release
- [ ] Remove deprecated lambda container image code - https://docs.sentry.io/platforms/node/guides/aws-lambda/container-image/