-
Notifications
You must be signed in to change notification settings - Fork 37
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 sourcemap upload duration for multi-stage builds #626
Comments
@lforst Very interested in this 🙂 We have an SST repo that takes around 40 minutes to build when Sentry's ESBuild plugin is enabled. It more than doubles our build time (which wasn't fast to begin with). The benefits of having the source code available in Sentry issues still outweigh the added build time, but it is properly painful. |
@joaocanaverde-blue thanks for chiming in, definitely appreciate the feedback and hearing of actual pain points. We have this in our backlog and hopefully get to it soon. |
One thing you could do today to limit the impact is to remove the plugin in favour of using Sentry CLI directly. You could inject debugIds and upload source maps once at the end of all your builds and point the CLI to all files. Just as an alternative suggestion if you don't want to wait for the change in the plugin. This comes with the disadvantage that |
Thanks @andreiborza and @Lms24! I had previously tried to use this approach (which uses Sentry's CLI) without much success. I then tried Sentry's ESBuild plugin. That worked without much fuss, so I left it despite the slowness. @Lms24 really appreciate your suggestion - it gave me the push to give the CLI approach another go. Really thought it would work this time, but unfortunately the only way I can see the source code in Sentry is still by using the ESBuild plugin. This is very likely to just be an SST quirk, but for the record this is what I'm doing when using the CLI approach:
I've also experimented with creating a release instead of injecting debug ids. That got me as far as the I spent most of yesterday on this so I think I'm going to revert to the ESBuild plugin again and live with slow builds for now. |
Just to confirm: This means that the |
@Lms24 yup, I can see The only thing missing at that point is the code mapping to the original I've also tried to include the And if I try to click the "Set up Code Mapping" button on Sentry and paste the relevant GitHub link, Sentry tells me it's not the same file (presumably because it's expecting an Guessing the ESBuild plugin must be doing something extra that I'm not. |
Oh does this mean that the source map itself is maybe incorrect? You could try inspecting the source map with for example this tool. |
@Lms24 Possibly? Troubleshooting the CLI approach has proved to not be trivial. At this stage I think it's better for me to hold off until this ESBuild issue gets resolved. It does at least work, as long as I'm patient 🙂 Thanks for all your help so far! |
I ran into the exact same problem as @joaocanaverde-blue and basically followed the same steps until giving up and just using the plugin. We similarly see our CI duration double due to the plugin. I've spent around a week or so attempting to get this working with the sentry cli directly. Also an SST application. |
I'll limit this issue to Next.js because it is a super-set of everything else.
In high-level frameworks there are often multiple build-passes the framework does. This can cause the Sentry plugin to pick up and upload the same files multiple times, potentially leading to unnecessarily long uploads.
Brainstorming a solution:
Related getsentry/sentry-javascript#14132
The text was updated successfully, but these errors were encountered: