Nginx 配置websocket反向代理(Version:1.14.2)

  • 要将客户端和服务器之间的连接从HTTP/1.1转换为WebSocket,请使用HTTP/1.1中提供的协议交换机制。

  • 然而,有一个微妙之处:由于“Upgrade”是 hop-by-hop标头,因此它不会从客户端传递到代理服务器。通过转发代理,客户端可以使用该CONNECT 方法来规避此问题。但是,这不适用于反向代理,因为客户端不知道任何代理服务器,并且需要在代理服务器上进行特殊处理。

  • 从版本1.3.13开始,nginx实现了特殊的操作模式,如果代理服务器返回带有代码101(交换协议)的响应,则允许在客户端和代理服务器之间建立隧道,并且客户端要求通过请求中的“Upgrade”标头。

  • 如上所述,包括“Upgrade”和“CONNECT”的逐跳报头不会从客户端传递到代理服务器,因此为了让代理服务器知道客户端将协议切换到WebSocket的意图,这些报头必须明确传递:

location /chat/ {
    proxy_pass http://backend;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
}
  • 一个更复杂的示例,其中对代理服务器的请求中的“ Connection”标头字段的值取决于客户端请求标头中是否存在“Upgrade”字段:
http {
    map $http_upgrade $connection_upgrade {
        default upgrade;
        ''      close;
    }

    server {
        ...

        location /chat/ {
            proxy_pass http://backend;
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection $connection_upgrade;
        }
    }

默认情况下,如果代理服务器在60秒内未传输任何数据,则将关闭连接。使用proxy_read_timeout指令可以增加此超时 。或者,代理服务器可以配置为定期发送WebSocket ping帧以重置超时并检查连接是否仍然存在。

你可能感兴趣的:(Nginx 配置websocket反向代理(Version:1.14.2))