Real-time Communication: WebSockets, SSE & Polling
Learn the interview-ready mental model, practical trade-offs, and production patterns for this web fundamentals topic.
Topic content
Real-time features require choosing the right transport based on directionality, latency needs, scaling complexity, and operational cost. WebSockets offer full bidirectional communication but are stateful and harder to scale. Server-Sent Events provide simple unidirectional push with built-in reconnection. Polling is easiest but least efficient.
WebSockets = a phone call (both can talk anytime). SSE = a radio broadcast (server talks, you listen). Polling = repeatedly calling to ask 'anything new?' The best choice depends on how often each side needs to speak and how reliably the connection must stay open.
1WebSockets
Persistent, bidirectional, full-duplex connection. Excellent for chat, collaborative editing, and multiplayer games. Requires careful connection management, reconnection logic, and horizontal scaling (often with Redis Pub/Sub).
useEffect(() => {
const ws = new WebSocket(WS_URL);
ws.onmessage = (e) => handleMessage(JSON.parse(e.data));
return () => ws.close();
}, []);2Server-Sent Events (SSE)
Unidirectional server-to-client streaming over HTTP. Simpler than WebSockets with built-in reconnection and event IDs. Ideal for notifications, live feeds, and progress updates.
3Polling Strategies
Short polling (fixed interval) is simple but wasteful. Long polling holds the connection open until data arrives. Use only when real-time requirements are relaxed.
4Scaling, Reconnection & Consistency
Plan for reconnection with exponential backoff + jitter. Use message ordering, idempotency, and client-side reconciliation to handle missed or out-of-order events.
- ✓WebSockets for bidirectional real-time
- ✓SSE for simple, reliable server push
- ✓Polling as fallback or for low-frequency updates
- ✓Always implement reconnection with backoff + jitter
- ✓Ensure event ordering and idempotency on client
- ✓Plan for horizontal scaling from day one
- ✓Choose transport based on direction, latency, and complexity