WebSocket 1003 Unsupported Data vs 1012 Service Restart
Both WebSocket 1003 (Unsupported Data) and 1012 (Service Restart) belong to the WebSocket Close Codes category. 1003 indicates that an endpoint received a type of data it cannot accept. For example, a text-only endpoint received a binary message, or vice versa. Meanwhile, 1012 means that the server is terminating the connection because it is restarting. The client should reconnect after a brief delay.
描述
An endpoint received a type of data it cannot accept. For example, a text-only endpoint received a binary message, or vice versa.
何时出现
The client sent a binary frame to a server that only handles text, or a text frame to a binary-only endpoint. The receiver does not know how to process this data type.
如何修复
Verify the message type (text vs binary) matches what the server expects. Update your client to send the correct opcode for the data format.
描述
The server is terminating the connection because it is restarting. The client should reconnect after a brief delay.
何时出现
The server is performing a planned restart — for example, during a deployment or configuration reload. The connection will be available again shortly.
如何修复
Implement automatic reconnection with a short delay (1-5 seconds). This code signals that reconnecting is expected and should succeed once the server is back up.
主要区别
WebSocket 1003: An endpoint received a type of data it cannot accept. For example, a text-only endpoint received a binary message, or vice versa.
WebSocket 1012: The server is terminating the connection because it is restarting. The client should reconnect after a brief delay.
You encounter 1003 when the client sent a binary frame to a server that only handles text, or a text frame to a binary-only endpoint. The receiver does not know how to process this data type.
You encounter 1012 when the server is performing a planned restart — for example, during a deployment or configuration reload. The connection will be available again shortly.
何时使用哪个
For 1003 (Unsupported Data): Verify the message type (text vs binary) matches what the server expects. Update your client to send the correct opcode for the data format. For 1012 (Service Restart): Implement automatic reconnection with a short delay (1-5 seconds). This code signals that reconnecting is expected and should succeed once the server is back up.