《Nginx官方文档》WebSocket代理 

WebSocket代理

要将客户机和服务器之间的连接从HTTP / 1.1转换为WebSocket,要使用HTTP / 1.1中可用的 协议切换 机制。

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

1.3.13版本以来,nginx实现了特殊的操作模式,如果代理的服务器使用代码101(交换协议)返回响应,则客户机和代理服务器之间建立隧道,客户端通过请求中的“升级”头。

如上所述,包括“升级”和“连接”的逐跳报头不会从客户端传递到代理服务器,因此为了使代理的服务器知道客户端将协议切换到WebSocket的意图,这些头文件必须明确地通过:

location /chat/ {
    proxy_pass http://backend;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header 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帧以重置超时并检查连接是否仍然存在。

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/99542.html

(0)
上一篇 2021年8月21日
下一篇 2021年8月21日

相关推荐

发表回复

登录后才能评论