nginx配置websocket负载均衡

nginx配置websocket负载均衡

配置Nginx

修改Nginx主配置文件

$ vim /usr/local/nginx/conf/nginx.conf


在http上下文中增加如下配置,确保Nginx能处理正常http请求,由于一般情况下开发人员在开发的过程中会将websocket的会话状态session通过集合进行管理存储于内存中,则在多节点分布式的情况下,可使用IP_HASH负载策略进行负载解决session不一致的问题。

http{  map $http_upgrade $connection_upgrade {    default upgrade;    ''      close;  }  upstream websocket {    ip_hash;    server localhost:8010;      server localhost:8011;  }


以下配置是在server上下文中添加,location指用于websocket连接的path。

server {    listen       80;    server_name localhost;    access_log /var/log/nginx/yourdomain.log;    location / {      proxy_pass http://websocket;      proxy_read_timeout 300s;      proxy_set_header Host $host;      proxy_set_header X-Real-IP $remote_addr;      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;      proxy_http_version 1.1;      proxy_set_header Upgrade $http_upgrade;      proxy_set_header Connection $connection_upgrade;        }    }}


最重要的就是在反向代理的配置中增加了如下两行,其它的部分和普通的HTTP反向代理没有任何差别。

proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection $connection_upgrade;


这里面的关键部分在于HTTP的请求中多了如下头部:

Upgrade: websocketConnection: Upgrade


这两个字段表示请求服务升级协议为WebSocket。服务器处理完请求后,响应如下报文:
# 状态码为101

HTTP/1.1 101 Switching ProtocolsUpgrade: websocketConnection: upgrade


告诉客户端已成功切换协议,升级为Websocket协议。握手成功之后,服务器端和客户端便角色对等,就像普通的Socket一样,能够双向通信。不再进行HTTP的交互,而是开始WebSocket的数据帧协议实现数据交换。

这里使用map指令可以将变量组合成为新的变量,会根据客户端传来的连接中是否带有Upgrade头来决定是否给源站传递Connection头,这样做的方法比直接全部传递upgrade更加优雅。

默认情况下,连接将会在无数据传输60秒后关闭,proxy_read_timeout参数可以延长这个时间或者源站通过定期发送ping帧以保持连接并确认连接是否还在使用。

免责声明:本网信息来自于互联网,目的在于传递更多信息,并不代表本网赞同其观点。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,并请自行核实相关内容。本站不承担此类作品侵权行为的直接责任及连带责任。如若本网有任何内容侵犯您的权益,请及时联系我们,本站将会在24小时内处理完毕。
相关文章
返回顶部