1xx Informational

101 Switching Protocols

What it means

The server agrees to the protocol upgrade requested by the client via the Upgrade header. Most commonly seen when upgrading an HTTP connection to a WebSocket connection. The connection will no longer use HTTP after this response — the new protocol takes over.

Site Visitor

What can I do?

  • No action needed — this is an informational or success response, not an error.
Developer

How to debug & fix

  1. Verify your Upgrade and Connection: Upgrade headers are present and correctly spelled
  2. Ensure your reverse proxy (Nginx, Caddy) forwards the Upgrade header for WebSocket support
  3. Check that your server framework supports the target protocol
  4. Check that your reverse proxy (Nginx, HAProxy) correctly forwards the Connection: Upgrade and Upgrade headers.
  5. Test WebSocket connectivity with wscat: wscat -c wss://yourhost/ws

Code Example

Node.js / Express
// Node.js WebSocket upgrade
const { createServer } = require('http');
const server = createServer();
server.on('upgrade', (req, socket, head) => {
  // Server sends 101 automatically on WebSocket upgrade
  wss.handleUpgrade(req, socket, head, ws => {
    wss.emit('connection', ws, req);
  });
});

Related Status Codes

How HTTP Status Codes Work

Every HTTP response carries a three-digit status code that tells the client — browser, API consumer, or search-engine crawler — exactly what happened. The first digit defines the class: 1xx informational (request in progress), 2xx success, 3xx redirection, 4xx client error (bad request, missing auth, not found), and 5xx server failure.

Status codes are standardised in RFC 9110 (HTTP Semantics, 2022). Extensions like WebDAV (RFC 4918) and rate-limit headers (RFC 6585) added codes beyond the core set. When a client receives an unrecognised code, the rule is to treat it as the generic x00 of its class.

Why the Right Code Matters

Semantically correct codes help search engines index accurately (301 passes link equity; 410 removes pages faster than 404), allow API clients to implement correct retry logic (429 + Retry-After, 503 + Retry-After), and let monitoring systems distinguish bugs (500) from load issues (503) from auth failures (401/403).

Looking up a different status code? The full reference covers all HTTP codes with causes, fix guides, and copyable code examples for Node.js and Python.

Browse the full HTTP Status Code reference →

Frequently Asked Questions

What does HTTP 101 Switching Protocols mean?
The server agrees to the protocol upgrade requested by the client via the Upgrade header. Most commonly seen when upgrading an HTTP connection to a WebSocket connection. The connection will no longer use HTTP after this response — the new protocol takes over.
Is HTTP 101 the visitor's fault?
No. HTTP 101 Switching Protocols is an informational or success response. It is not caused by anything the visitor did wrong.
How do I fix HTTP 101 Switching Protocols?
HTTP 101 Switching Protocols is not an error — no fix is needed. Developers should ensure their HTTP client correctly handles this interim or success response.