Nginx实战之反向代理WebSocket的配置实例

                                   Nginx实战之反向代理WebSocket的配置实例

  1. 案例1:源码安装Redis缓存服务

 

1案例:Nginx实战之反向代理WebSocket的配置实例

http://www.jb51.net/article/112183.htm

最近在工作中遇到一个需求,需要使用 nginx 反向代理websocket,经过查找一番资料,目前已经测试通过,所以这篇文章主要给大家介绍了Nginx反向代理WebSocket配置的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。

 

实现方案

采用目前比较成熟的WebSocket技术,WebSocket协议为创建客户端和服务器端需要实时双向通讯的webapp提供了一个选择。其为HTML5的一部分,WebSocket相较于原来开发这类app的方法来说,其能使开发更加地简单。大部分现在的浏览器都支持WebSocket,比如FirefoxIEChromeSafariOpera,并且越来越多的服务器框架现在也同样支持WebSocket

WebSocket集群

在实际的生产环境中,要求多个WebSocket服务器必须具有高性能和高可用,那么WebSocket协议就需要一个负载均衡层,NGINX1.3开始支持WebSocket,其可以作为一个反向代理和为WebSocket程序做负载均衡。

Nginx配置

注:看官方文档说 Nginx 1.3 以后的版本才支持 websocket 反向代理,所以要想使用支持 websocket 的功能,必须升级到 1.3 以后的版本

NGINX通过允许一个在客户端和后端服务器之间建立的隧道来支持WebSocket。为了NGINX发送来至于客户端Upgrade请求到后端服务器,UpgradeConnection头部必须被设置明确。

 

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反向代理实现websocketvar 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那样是典型的短连接,所以反向代理服务器需要允许连接保持着打开,而不是在它们看起来空闲时就将它们关闭。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

 

posted @ 2019-11-27 16:23  云计算(互联网)  Views(305)  Comments(0Edit  收藏  举报