With the rising demand for sync engines and real-time feature, WebSockets have become a critical component for modern applications. At Compose, WebSoc

Lessons from scaling WebSockets at Compose

submited by
Style Pass
2025-01-24 20:00:04

With the rising demand for sync engines and real-time feature, WebSockets have become a critical component for modern applications. At Compose, WebSockets form the backbone of our service, powering our backend SDKs that enable developers to deliver low-latency interactive applications with just backend code.

But, scaling WebSockets has proven to be far more complex than we expected. Below are some of the most important lessons we've learned along the way.

After 4 consecutive 503 responses, the load balancer declares the server unhealthy and removes the old servers from the pool. The load balancer health checks every 5 seconds, so this process takes up to 25 seconds.

The custom close message lets clients show users a more accurate message during the ~10 second period where the client is disconnected.

The random delay helps prevent thundering herd issues where all clients reconnect at once. Clients also double the exponential backoff for deployment-related reconnections to account for unforseen issues.

Leave a Comment