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

WebSocket client drops some incoming messages when running locally #983

Closed
rnbrady opened this issue Oct 4, 2024 · 9 comments
Closed

WebSocket client drops some incoming messages when running locally #983

rnbrady opened this issue Oct 4, 2024 · 9 comments

Comments

@rnbrady
Copy link

rnbrady commented Oct 4, 2024

Bug Report

A WebSocket client instantiated in the Edge runtime will randomly drop incoming messages from the WedSocket server. In my test every 10th or so incoming message is dropped, but it probably depends on timing and message length (edit: it's actually triggered by a websocket keepalive).

Possible solution

This appears to be caused by by upstream bug nodejs/undici#2859 which has been fixed and released in nodejs/undici@6.17.

Bumping Undici from 5 to 6 appears to be a breaking change so Dependabot hasn't been able to do it automatically. Possibily complicating matters further is that Undici v6 does not support Node v16.

Additional context/screenshots

In my application I'm connecting from a server-side Edge function to a Bitcoin indexer over WebSocket to subscribe to balance updates which I then send to the client as server-sent events (SSE). After an initial handshake I ping the indexer over WebSocket every second, and the pongs are received except that every 10th or so one gets dropped and a null message is delivered:

Screenshot 2024-10-04 at 16 20 26

With OpenAI recently annoucing their Realtime API based on WebSockets, other developers might soon run into this problem too.

tl;dr: please try and merge #947 🙏

rnbrady added a commit to rnbrady/vercel-edge-runtime-983 that referenced this issue Oct 6, 2024
@rnbrady
Copy link
Author

rnbrady commented Oct 6, 2024

On further investigation the problem occurs when the server sends a websocket ping message. See rnbrady/vercel-edge-runtime-983 to reproduce.

Screenshot 2024-10-05 at 23 13 22

@rnbrady rnbrady changed the title WebSocket client drops incoming messages WebSocket client drops some incoming messages Oct 6, 2024
@rnbrady rnbrady changed the title WebSocket client drops some incoming messages WebSocket client drops some incoming messages in dev mode Oct 6, 2024
@rnbrady rnbrady changed the title WebSocket client drops some incoming messages in dev mode WebSocket client drops some incoming messages when running locally Oct 6, 2024
@rnbrady
Copy link
Author

rnbrady commented Oct 6, 2024

I am unable to reproduce this bug in deployments to Vercel.

To aid in testing I have deployed the server.mjs echo server which sends a ping every 3s to the following public address:
https://vercel-edge-runtime-983-ws-server-1014083751163.europe-west2.run.app

@rnbrady
Copy link
Author

rnbrady commented Oct 22, 2024

This might be resolved by #546.

@Kikobeats
Copy link
Member

Hello, this is going to be tricky to resolve since edge-runtime still supports Node.js v16, and to make this possible we are sticky to undici v5:

https://github.com/vercel/edge-runtime/blob/main/packages/primitives/package.json#L33

The fix for the undici websocket version was shipped under undici v6, which is dropping Node.js v16 support.

So in order to ship this we need to drop Node.js v16 support and upgrade (or drop) Undici , which is covered in #546

@rnbrady
Copy link
Author

rnbrady commented Nov 21, 2024

Thanks for the reply @Kikobeats. I'm happy to wait for #546.

I just looked into how Cloudflare Workers does WebSocket in local dev and it turns out they have problems too, so I appreciate it's not an easy probem to solve.

@Kikobeats
Copy link
Member

Edge Runtime v4 has been, dropping node18 support and it's now using undici@6.

This should be fix your issue @rnbrady as soon as soon as the new version starts being used in Next.js:
vercel/next.js#73432

@rnbrady
Copy link
Author

rnbrady commented Dec 2, 2024

Thanks @Kikobeats, I will try it out once it's merged and let you know. Appreciate your work on this. Dev prod disparity in Edge functions has taken me on quite a ride lately, so this will be a nice fix to have. Appreciate your work.

@Kikobeats
Copy link
Member

It's shipped starting from Next.js v15.0.4-canary.37

Closing but please tell me if it's working fine for you now 🙂

@rnbrady
Copy link
Author

rnbrady commented Dec 5, 2024

@Kikobeats I can confirm this is fixed. Tested against 15.0.4-canary.41. Thank you so much. This will allow me to significantly simplify my dev environment.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants