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

举报
lxw1844912514 发表于 2022/03/28 01:35:46 2022/03/28
【摘要】 最近在工作中遇到一个需求,需要使用 nginx 反向代理websocket,经过查找一番资料,目前已经测试通过,所以这篇文章主要给大家介绍了Nginx反向代理WebSocket配置的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。 实现方案 采用目前比较成熟的WebSocket技术,WebSocket协议为创建客...

最近在工作中遇到一个需求,需要使用 nginx 反向代理websocket,经过查找一番资料,目前已经测试通过,所以这篇文章主要给大家介绍了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头部必须被设置明确。


    
  1. upstream wsbackend {
  2. server 127.0.0.1:8080;
  3. server 127.0.0.1:8081;
  4. }
  5. server {
  6. listen 80;
  7. server_name ws.52itstyle.com;
  8. location / {
  9. proxy_pass http://wsbackend;
  10. proxy_http_version 1.1;
  11. proxy_set_header Upgrade $http_upgrade;
  12. proxy_set_header Connection "upgrade";
  13. }
  14. }

前端配置:

    
  1. $(function(){
  2. socket.init();
  3. });
  4. //Nginx反向代理实现websocket
  5. var basePath = "ws://ws.52itstyle.com//acts_competition/";
  6. socket = {
  7. webSocket : "",
  8. init : function() {
  9. if ('WebSocket' in window) {
  10. webSocket = new WebSocket(basePath+'webSocketServer');
  11. }
  12. else if ('MozWebSocket' in window) {
  13. webSocket = new MozWebSocket(basePath+"webSocketServer");
  14. }
  15. else {
  16. webSocket = new SockJS(basePath+"sockjs/webSocketServer");
  17. }
  18. webSocket.onerror = function(event) {
  19. //alert("websockt连接发生错误,请刷新页面重试!")
  20. };
  21. webSocket.onopen = function(event) {
  22. };
  23. webSocket.onmessage = function(event) {
  24. };
  25. },
  26. sendData : function(data) {
  27. webSocket.send(data);
  28. },
  29. }

最后,重启下Nginx即可。

反向代理服务器在支持WebSocket时面临的挑战

  • WebSocket是端对端的,所以当一个代理服务器从客户端拦截一个Upgrade请求,它需要去发送它自己的Upgrade请求到后端服务器,也包括合适的头。
  • 因为WebSocket是一个长连接,不像HTTP那样是典型的短连接,所以反向代理服务器需要允许连接保持着打开,而不是在它们看起来空闲时就将它们关闭。

文章来源: blog.csdn.net,作者:lxw1844912514,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/lxw1844912514/article/details/100027391

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。