Nginx转发socket和负载均衡

1.socket转发
这边遇到一个坑:就是不能把配置写入http下,如图


图中配的upstream socket 里面的两个server做的就是负载;
参考官方文档遇到深坑,官方文档给的是这个:
没玩转。图一中的负载有缺陷,只能默认跳转到第一个服务器,这个bug希望有大佬能帮到,后期也会抽时间搞定!
以下是Nginx转发http和负载均衡:https://blog.csdn.net/wang20y8/article/details/99682636

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您解答这个问题。 首先,您可以使用 Nginx 作为代理来处理 WebSocket 请求。但是,由于 WebSocket 是基于 HTTP 协议的,因此需要在 Nginx 配置文件中添加一些特殊的指令来支持 WebSocket 协议。 以下是一个基本的 Nginx 配置文件示例,可用于代理 Socket.io/WebSocket: ``` http { upstream websocket { # 定义负载均衡策略,这里使用轮询 # 如果您有多个 WebSocket 服务器,可以将它们添加到这个 upstream 块中 server server1:3000; server server2:3000; server server3:3000; } server { listen 80; # 这里添加一些常规的 Nginx 配置指令,例如 server_name、access_log 等 location /socket.io/ { # WebSocket 协议需要使用 HTTP/1.1 协议 proxy_http_version 1.1; # 开启长连接 proxy_set_header Connection "Upgrade"; # 开启协议升级模式 proxy_set_header Upgrade $http_upgrade; # 负载均衡 proxy_pass http://websocket; proxy_redirect off; proxy_read_timeout 60s; } # 其他 location 配置指令 } } ``` 在上面的配置中,我们使用 upstream 块来定义 WebSocket 服务器。这里使用轮询策略,将请求分发到三个服务器上。在 location 块中,我们使用 proxy_http_version、proxy_set_header 和其他一些指令来启用 WebSocket 协议和负载均衡。在 proxy_pass 指令中,我们将请求转发到定义的 upstream 服务器。 请注意,在使用 Nginx 代理 WebSocket 时,必须确保负载均衡服务器和 WebSocket 服务器之间的连接是长连接。否则,WebSocket 连接可能会因为连接关闭而中断。 希望这个回答可以帮助到您。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值