WebSocket

WebSocket 1000 Normal Closure vs 1001 Going Away

Both WebSocket 1000 (Normal Closure) and 1001 (Going Away) belong to the WebSocket Close Codes category. 1000 indicates that the connection has been closed cleanly, meaning the purpose for which it was established has been fulfilled. Both endpoints agree the session is complete. Meanwhile, 1001 means that an endpoint is going away, such as a server shutting down or a browser navigating away from the page. The connection must be closed.

Описание

The connection has been closed cleanly, meaning the purpose for which it was established has been fulfilled. Both endpoints agree the session is complete.

Когда вы это видите

The WebSocket connection closed gracefully after both sides finished exchanging data. This is the expected close code for a successful session.

Как исправить

No fix needed — this indicates everything worked as intended. If you did not expect the connection to close, check your application logic for premature close() calls.

Описание

An endpoint is going away, such as a server shutting down or a browser navigating away from the page. The connection must be closed.

Когда вы это видите

The server is shutting down for maintenance, or the user navigated away from the page or closed the browser tab while a WebSocket was open.

Как исправить

Implement automatic reconnection logic with exponential backoff in your client. If the server is restarting, the client should retry after a short delay.

Ключевые различия

1.

WebSocket 1000: The connection has been closed cleanly, meaning the purpose for which it was established has been fulfilled. Both endpoints agree the session is complete.

2.

WebSocket 1001: An endpoint is going away, such as a server shutting down or a browser navigating away from the page. The connection must be closed.

3.

You encounter 1000 when the WebSocket connection closed gracefully after both sides finished exchanging data. This is the expected close code for a successful session.

4.

You encounter 1001 when the server is shutting down for maintenance, or the user navigated away from the page or closed the browser tab while a WebSocket was open.

Когда что использовать

For 1000 (Normal Closure): No fix needed — this indicates everything worked as intended. If you did not expect the connection to close, check your application logic for premature close() calls. For 1001 (Going Away): Implement automatic reconnection logic with exponential backoff in your client. If the server is restarting, the client should retry after a short delay.

Узнать больше