![4955245028ce67e8c46bb6866de09258.png](https://img-blog.csdnimg.cn/img_convert/4955245028ce67e8c46bb6866de09258.png)
写在开始
去年,做过一款竞赛打分的APP。具体需求,同组教师之间可以相互通信,及时通知同组人员,其他组员做了那些操作(当然,这只是针对特定操作)。
![9e4ea7e1dcafba01f62f54cc002b152b.png](https://img-blog.csdnimg.cn/img_convert/9e4ea7e1dcafba01f62f54cc002b152b.png)
实现方案
采用目前比较成熟的WebSocket技术,WebSocket协议为创建客户端和服务器端需要实时双向通讯的webapp提供了一个选择。其为HTML5的一部分,WebSocket相较于原来开发这类app的方法来说,其能使开发更加地简单。大部分现在的浏览器都支持WebSocket,比如Firefox,IE,Chrome,Safari,Opera,并且越来越多的服务器框架现在也同样支持WebSocket。
WebSocket集群
在实际的生产环境中,要求多个WebSocket服务器必须具有高性能和高可用,那么WebSocket协议就需要一个负载均衡层,NGINX从1.3开始支持WebSocket,其可以作为一个反向代理和为WebSocket程序做负载均衡。
Nginx配置
注:看官方文档说 Nginx 在 1.3 以后的版本才支持 websocket 反向代理,所以要想使用支持 websocket 的功能,必须升级到 1.3 以后的版本
NGINX通过允许一个在客户端和后端服务器之间建立的隧道来支持WebSocket。为了NGINX发送来至于客户端Upgrade请求到后端服务器,Upgrade和Connection头部必须被设置明确。
代码实例:
![0653440c5039abb2b9e7a4af5e57a4ce.png](https://img-blog.csdnimg.cn/img_convert/0653440c5039abb2b9e7a4af5e57a4ce.png)
前端配置:
![4681bd85371887df5d66c4ebabd841cb.png](https://img-blog.csdnimg.cn/img_convert/4681bd85371887df5d66c4ebabd841cb.png)
最后,重启下Nginx即可。
反向代理服务器在支持WebSocket时面临的挑战
WebSocket是端对端的,所以当一个代理服务器从客户端拦截一个Upgrade请求,它需要去发送它自己的Upgrade请求到后端服务器,也包括合适的头。
因为WebSocket是一个长连接,不像HTTP那样是典型的短连接,所以反向代理服务器需要允许连接保持着打开,而不是在它们看起来空闲时就将它们关闭。
![895381e0f1d8a3867bd9d1c8e867ea5e.png](https://img-blog.csdnimg.cn/img_convert/895381e0f1d8a3867bd9d1c8e867ea5e.png)