Nginx实战之反向代理WebSocket的配置实例
实现方案
采用目前比较成熟的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头部必须被设置明确。
代码实例:
upstream wsbackend { server 127.0.0.1:8080; server 127.0.0.1:8081; } server { listen 80; server_name ws.52itstyle.com; location / { proxy_pass http://wsbackend; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; } }
前端配置:
$(function(){ socket.init(); }); //Nginx反向代理实现websocket var basePath = "ws://ws.52itstyle.com//acts_competition/"; socket = { webSocket : "", init : function() { if ('WebSocket' in window) { webSocket = new WebSocket(basePath+'webSocketServer'); } else if ('MozWebSocket' in window) { webSocket = new MozWebSocket(basePath+"webSocketServer"); } else { webSocket = new SockJS(basePath+"sockjs/webSocketServer"); } webSocket.onerror = function(event) { //alert("websockt连接发生错误,请刷新页面重试!") }; webSocket.onopen = function(event) { }; webSocket.onmessage = function(event) { }; }, sendData : function(data) { webSocket.send(data); }, }
最后,重启下Nginx即可。
反向代理服务器在支持WebSocket时面临的挑战
WebSocket是端对端的,所以当一个代理服务器从客户端拦截一个Upgrade请求,它需要去发送它自己的Upgrade请求到后端服务器,也包括合适的头。
因为WebSocket是一个长连接,不像HTTP那样是典型的短连接,所以反向代理服务器需要允许连接保持着打开,而不是在它们看起来空闲时就将它们关闭。
原文链接:http://blog.52itstyle.com/archives/736/
(资源库 www.zyku.net)
上一篇:利用Nginx反向代理与负载均衡搭建多人测试环境详解
栏 目:Nginx
本文标题:Nginx实战之反向代理WebSocket的配置实例
本文地址:https://www.zyku.net/nginx/1331.html
您可能感兴趣的文章
- 06-03nginx反向代理导致session失效的问题解决
- 04-22Nginx反向代理后获取不到客户端的真实ip地址的解决方
- 09-25Nginx反向代理docker容器进行域名解析绑定的实现方法
- 04-03利用Nginx反向代理与负载均衡搭建多人测试环境详解
- 03-17详解 Nginx 负载均衡和反向代理配置和优化
- 02-20Apache设置反向代理解决js跨域问题
- 05-10php判断数组是否为空的实例方法
- 02-09小米11设置息屏消息通知光效样式
- 03-15sublime text 3文件路径没有提示的设
- 01-09卓越优化助手-卓越优化助手应用软件功
- 03-03iPhone12发热解决办法
- 03-04wordpress防止垃圾评论的几种方法
- 01-12毫秒连WiFi-毫秒连WiFi应用软件功能介
- 02-09opporeno5悬浮球设置流程
- 04-24Python 条件判断的缩写方法
- 01-12集团管控-集团管控应用软件功能介绍
- 10-15iPhone13Pro怎样关闭家人共享
- 01-15一加10pro蓝牙功能
- 10-29钉钉怎么取消工作状态
- 07-29jquery v2.0.0
最近更新
阅读排行
猜你喜欢
- 01-11一键音频剪辑-一键音频剪辑应用软件功
- 02-18CSS实现带箭头的流程进度条
- 09-22钉钉在线课堂功能在哪里
- 01-12八局通-八局通应用软件功能介绍
- 08-11豆瓣如何删除动态
- 04-16帝国CMS调用会员头像没有头像时显示默
- 01-11乙教育-乙教育应用软件功能介绍
- 11-18苹果13相机微距控制开关使用教程分享
- 01-11惠享优选-惠享优选应用软件功能介绍
- 03-31使用python批量生成insert语句的方法