Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve AWS Lambda experience #12409

Closed
7 of 8 tasks
Lms24 opened this issue Jun 7, 2024 · 4 comments
Closed
7 of 8 tasks

Improve AWS Lambda experience #12409

Lms24 opened this issue Jun 7, 2024 · 4 comments
Assignees
Labels
Package: aws-serverless Issues related to the Sentry AWS Serverless SDK Type: Improvement

Comments

@Lms24
Copy link
Member

Lms24 commented Jun 7, 2024

I investigated AWS lambda support in the last couple of days and found multiple issues we should tackle to improve the SDK/Usage experience with our @sentry/aws-serverless SDK and AWS Lambda layer:

ESM Lambda Support

Preview Give feedback
  1. Lms24
  2. Lms24

ESM Lambda Layer

Preview Give feedback
  1. 0 of 9
    Feature: Serverless Package: aws-serverless
    andreiborza
@G-Rath
Copy link

G-Rath commented Jun 9, 2024

Not sure if you're already tracking this or what, but fwiw it looks like switching to @sentry/aws-serverless adds an extra 2.2mb to my lambdas - it doesn't sound like a stated or expected goal, and I imagine some "new" size is in new feature stuff, but it still feels like a weird jump given #11052 says "removes all GCP related code".

Something else I find telling is that installing @sentry/serverless only adds 19 packages whereas @sentry/aws-serverless adds 82 on my project apparently - again, not the end of the world and I've not done any digging, but thought you might be interested 🙂

The lambdas themselves are typescript based, compiled with serverless v3 + tsc as per https://github.com/ackama/serverless-aws-template

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Jun 9, 2024
@Lms24
Copy link
Member Author

Lms24 commented Jun 10, 2024

@G-Rath the increase in dependencies and size is caused by us switching to OpenTelemetry for instrumentation. By default, the our AWS Serverless SDK does not include performance instrumentation (e.g. for databases like postgres). However, if you only use tsc to build your functions I'm fairly sure that some unused code and dependecies are not tree-shaken out. Meaning your build might be larger than it has to be.

Have you looked into bundlers like rollup? they should be able to tree-shake out all unused code.

That being said, I have never heard of sls before so not sure if it does any optimizations under the hood. My reference is basically manually zipping up a lambda function including its node_modules and deploying it with the AWS CLI. In this workflow, I know for sure that no code elimination is done at all.

Lms24 added a commit that referenced this issue Jun 10, 2024
…idn't wrap handler (#12407)

Fix span collision by checking if the AWS lambda handler was already
wrapped by Otel instrumentation and only if not starting our own root
span. The rest of our handler is still being used (i.e. the flushing
logic, error capturing, etc) regardless of otel wrapping.

Also Adjusted E2E tests to:
- more closely resemble the AWS environment
- enable auto patching of the handler with the Sentry SDK handler
- better check for Otel and manual spans

Ref #12409
billyvg pushed a commit that referenced this issue Jun 10, 2024
…idn't wrap handler (#12407)

Fix span collision by checking if the AWS lambda handler was already
wrapped by Otel instrumentation and only if not starting our own root
span. The rest of our handler is still being used (i.e. the flushing
logic, error capturing, etc) regardless of otel wrapping.

Also Adjusted E2E tests to:
- more closely resemble the AWS environment
- enable auto patching of the handler with the Sentry SDK handler
- better check for Otel and manual spans

Ref #12409
@G-Rath
Copy link

G-Rath commented Jun 14, 2024

@Lms24 thanks for following up so quickly, and sorry for my delay in responding.

You're right that neither tsc or sls do treeshaking - so far we've not used any tree shaking for our serverless functions as they're small enough, fast enough, and non-critical in their current form, and everytime I've looked at bundler integrations for serverless they've always seemed overly complex relative to that; totally accept those that downside is by our choice so if you've focused on optimizing size based on treeshaking that's fair (though I'm still a little sad that "us switching to " has resulted in such a huge leap but oh well that is what it is).

I have never heard of sls before so not sure if it does any optimizations under the hood

sls is the short cli command for the serverless framework - the main optimization v3 does out of the box is allow you to exclude whole files but that's part of the whole "you're not treeshaking" thing since it lets you axe "not javascript" kind of files emass rather than anything surgical.

(on an aside, it's a great way to get that "eehhh wat" feeling as you go through the list of file extensions in your node_modules - you (won't) be surprised at what stray files get captured in published packages...)

@Lms24
Copy link
Member Author

Lms24 commented Jul 26, 2024

I'm going to close this issue as the immediate work, including the docs update, was completed. We're tracking #12856 separately to further improve ESM support.

@Lms24 Lms24 closed this as completed Jul 26, 2024
@AbhiPrasad AbhiPrasad removed Type: Bug Package: serverless Issues related to the Sentry Serverless SDK labels Aug 2, 2024
@AbhiPrasad AbhiPrasad added the Package: aws-serverless Issues related to the Sentry AWS Serverless SDK label Aug 2, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Package: aws-serverless Issues related to the Sentry AWS Serverless SDK Type: Improvement
Projects
Archived in project
Development

No branches or pull requests

4 participants