-
-
Notifications
You must be signed in to change notification settings - Fork 29
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
NodeJS 22 issues/feedbacks tracker #87
Comments
I managed to complete a Node 22 build with macos arm64 after removing the android SDK (the change from the node/build repo), and then also removed the iOS simulator cache (which is nearly 50GB) |
@faulpeltz That's super! PR? 🚀 |
I would extend that also on x64 build to prevent any future issue with this :) |
I'm trying to find out why the x64 macos build on -13 is so fragile, I had it crash or timeout multiple times. But the cleanup seems not necessary for now because it has ~200GB free disk space, and I assume it will imrpove in the future 🤷♂️ I really don't want to complain about free Apple build infrastructure, but 14GB of free disk space is a bit of a stretch... |
Yeah definetely 😆 Also because storage nowdays doesn't cost that much, RAM and CPU does... |
Can I use this release in production now? |
@cage1618 If you are speaking about nodejs 22 I would say nope, but you can use nodejs 18/20 safely with latest release |
@robertsLando The Node 22 patch applies to the just-released 22.9 version without problems and all builds went through In this release they disabled Maglev (one of the JIT compilers) because of reported crashes So random crashes might be caused by latent Node 22 issues before 22.9, might make sense to bump the Node 22 version (but not urgent) |
@faulpeltz thanks for the info, I have an action to automatically create the patch, let me run it 🚀 |
I have created a workflow that automatically check for new nodejs versions: https://github.com/yao-pkg/pkg-fetch/actions/workflows/check-latest-node.yml |
release 5.15.0 is stable now? |
Using 5.15.0 to use latest nodejs 22 doesn't seem to work for my project.
Running it:
|
@balisaurus does it work with others nodejs version? |
Same problem here: node:internal/modules/cjs/loader:1254 Error: Cannot find module 'C:\snapshot\appname\dist\apps\server\main.js' Node.js v22.9.0 works with -t node20-win-x64 but not node22 |
Seems that the snapshot fs doesn't work for module loading on Windows in the Node 22 patch |
@BeneRasche The window issue related to nodejs 22 should be fixed on next release, please be patient. Thanks to @faulpeltz for the patch! |
We're waiting for this, right?
Based on how often nodejs releases, I think it will be either next week or mid October |
@thisjt yep, I'm sorry! Problem is that actually I cannot release patches for nodejs patches as them would become broke for actual pkg versions as the shas are shipped with npm so updating them would change them and work only for latest vesrsions. I already have a workflow that runs every day at midnight and opens a PR when a new patch is available |
@robertsLando nodejs had a release 4 days ago. I think it's time to patch 😬 let's gooo- or does it need to have a v22 release? Oh lol nvm my bad it needs a v22 release |
@thisjt thanks for letting me know! Seems my automated workflows picked up it correctly 4 days ago but the patches do not apply cleanly, let me try to fix this https://github.com/yao-pkg/pkg-fetch/actions/runs/11171900799/job/31057489528 BTW seems only node 20 has a new release for now |
node v22.10 is finally out! https://github.com/nodejs/node/releases/tag/v22.10.0 And with that node v23 is also out, hoping that we will also be supporting this. Not in a hurry tho, we're not sure yet on how stable v23 is. |
I often follow this library and hope to keep up with the latest version of Node.js. This morning, I tested the v22 version, but it is not yet available. I hope excellent authors can continue to follow up and look forward to the latest available v22 version. Finally, I would like to thank the contributors of |
New version is coming soon. The average delay I would like to keep between nodejs releases and pkg support for them is around 1 week, it depends on how many breaks there are on patches. |
pkg 5.16.0 is out now with node 20.18.0 and 22.10.0 support |
pkg-fetch probably needs an update for 22.10 binaries, too? |
@BeneRasche It's out already! |
Where? |
Oh you were speaking about patches so, anyway seems not an issue as we dropped that many patches ago and this only happens on node 22 :( |
In If there is another mechanism I don't know where it can be found - but maybe this is either just a result of a breaking change in Node 22 (or the new V8 version it uses) or maybe some new flags need to be set When looking at the produced code cache blob on Linux and Windows, the generated code is exactly the same for a small but non-working example, but the hashes for the read-only snapshots are different - if someone has an idea where these are coming from or where they are generated during build, maybe I can find out whats different |
Back from holidays now. Just a quick summary here. Seems the issue is related to Node 22 that added a check on the snapshot hash that fails when cross-building.
@faulpeltz have you been able to detect why this happens? I think that's the only available workaround we have here |
Not yet, I think comparing the snapshot blob data generated on different platforms might be worth investigating - the generated bytecode itself looks identical, so the crash must have something to do with the layout of the startup/v8 readonly snapshot This might be by design in V8 however - I wonder now this is handled in Node SEA for different platforms, or maybe it just ignores the code snapshot altogether and just starts from the source script again, because that fallback works in pkg too. |
@faulpeltz As I wrote above from what I know SEA blob is not using bytecode so it's not the same |
@robertsLando @faulpeltz Is there any workaround for this cross-platform build issue? |
just disable bytecode generation |
Is anyone experiencing performance problems with Node 22? Is it right to use 600-700 MB RAM in an average NestJS app? |
@tariksogukpinarperwatch could you please try to pakcage your application with nodejs 20/18 and see if the memory usage is the same? |
When I tried it with Node 20, the memory usage is the same, around 600MB on average. The application is running in cluster mode. Can you give any suggestions, thank you |
what is the memory usage of the same application not packaged? Anyway would be helpful to understand if this has been a regression or not as this doesn't seems to be an issue related to nodejs 22. I suggest to open a separated issue |
Hello, I've found an issue. On my Windows computer, I can compile Node.js 22 (the latest version 22.13.1) without any problems, generate Windows and Linux binaries, and run them successfully. However, when I build the binaries on WSL, the Windows program fails to run. It terminates immediately upon execution, with no output whatsoever. On the other hand, the Linux program can run properly. |
Hi @dingiyan, could you try to add |
I try it, bake the options to --options , and got same result . I think it may be that some low-level code behaves inconsistently across platforms |
@dingiyan I'm sorry for that but without any information about the error it's hard to identify the issue. @faulpeltz any clue about this? |
Isn't that the known existing issue with cross platform? Building on WSL is using the Linux binary and then running that on Windows |
@faulpeltz Yeah you are right, I thought the actual issue was causing some output but it was another. In order to keep track of this issue I have added it to the list here @dingiyan only available workaround for now is to use |
@robertsLando I use the |
I seems cross compilation without |
Yeah I saw also the report on #137. I'm a bit lost here... We would need some support maybe from someone working on nodejs core... |
Just to summarize the issue:
Regarding the bytecode/snapshots:
|
I tried to reach out @RaisinTen (the dev who implemented node sea feature on Node.js core) via PM and maybe he will take a look at this 🙏🏼 |
Not that it was brought up as an alternative, but I would love to use the SEA feature, but it still fails on certain NPM packages. I don't recall the exact issue I had, but I just couldn't get it to work. This project has been my only alternative so far, and I'd really love it if we could figure it out. Unfortunately, the issue is also a bit beyond my own skill set as well. 😅 |
The only way to use sea is to use a bundler like esbuild to create a single file of your application. Of course this will not work for npm modules that have native |
Correct. My current project uses esbuild and none of the packages I'm using includes a native Node module. SEA still fails for me. I'll have to try again soon to get the error message again - I think it has to do with a require statement, but also this isn't the issue to explore my issue in. 😅 |
Hi all, some questions regarding the sourceless builds bug: Is Node.js v22 the first one where this error started happening? Does it repro on earlier versions like v21 or older minor / patch versions in the v22 line? The first approach that comes to my mind is to bisect and find out the failing Node.js or V8 commit.
@faulpeltz Could you clarify this part? The sourceless code cache generated on platform X runs on X but fails on platform Y but it is identical to the sourceless code cache generated on platform Y which runs on platform Y but fails on X? If that's true, it would mean that the snapshot checksum embedded in the code cache that works on each platforms are identical but is still different from the expected snapshot checksum. In that case, I'd be interested in looking into what the expected snapshot checksum is. Re.
and
IIUC the issue might be fixed if the snapshot checksum embedded in the generated code cache matches another snapshot checksum. @faulpeltz might be interesting to trigger a crash from the snapshot checksum check maybe by adding a |
AFAIK yes, this is only happening with Node.js 22 |
I didnt try any versions older than v22.8 (yet), bisecting might be quite a lot of work because the patches need to be tweaked to apply cleanly
So the code cache generated on platform X runs on X but fails on Y (and generated on Y runs on Y and fails on X), and is nearly identical except the header with the kReadOnlySnapshotChecksum (at offset 0x10) and another few bytes which look like checksums in the middle of the blob Code cache generated on linux x64 for win x64 So the expected checksum is different on each platform. The check which fails is in |
NodeJS 22 support has been added starting from pkg 5.14.0 but many things have changed on NodeJS source and so also on our patch file so it needs some tests. Use this issue to submit your feedbacks and issues
KNOWN ISSUES:
MacOS ARM64 not available: feat: add Node 22 patch (#45) (by @faulpeltz) pkg-fetch#45. Reason is that ATM no github runner is able to produce a valid binary without going out of RAM or exceeding 6h max build time. Fixed in 5.14.1 - Ref fix: node 22 module filename resolution in win32 (#49) by @faulpeltz pkg-fetch#49Module Loading not working with Windows- Ref fix: restore mac arm64 build pkg-fetch#46Error: Cannot find module
--public
flag (to include sources)cc @faulpeltz
The text was updated successfully, but these errors were encountered: