Nginx实战之反向代理WebSocket的配置实例
实现⽅案
采⽤⽬前⽐较成熟的WebSocket技术,WebSocket协议为创建客户端和服务器端需要实时双向通讯的webapp提供了⼀个选择。其为HTML5的⼀部分,WebSocket相较于原来开发这类app的⽅法来说,其能使开发更加地简单。⼤部分现在的浏览器都⽀持WebSocket,⽐如Firefox,IE,Chrome,Safari,Opera,并且越来越多的服务器框架现在也同样⽀持WebSocket。
WebSocket集
websocket和socket在实际的⽣产环境中,要求多个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;
location / {
proxy_pass 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//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");
}
//alert("websockt连接发⽣错误,请刷新页⾯重试!")
};
};
};
},
sendData : function(data) {
webSocket.send(data);
},
}
最后,重启下Nginx即可。
反向代理服务器在⽀持WebSocket时⾯临的挑战
WebSocket是端对端的,所以当⼀个代理服务器从客户端拦截⼀个Upgrade请求,它需要去发送它⾃⼰的Upgrade请求到后端服务器,也包括合适的头。
因为WebSocket是⼀个长连接,不像HTTP那样是典型的短连接,所以反向代理服务器需要允许连接保持着打开,⽽不是在它们看起来空闲时就将它们关闭。
总结
以上就是这篇⽂章的全部内容了,希望本⽂的内容对⼤家的学习或者⼯作能带来⼀定的帮助,如果有疑问⼤家可以留⾔交流,谢谢⼤家对的⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论