nginx websocket ip_hash规则

本文介绍了如何利用nginx的ip_hash规则实现websocket的负载均衡。通过在不同的网段部署springboot的websocket demo项目,并设置不同的环境变量,确保每个实例运行在不同IP。nginx配置后,通过观察日志发现,websocket连接成功地在不同服务器间进行了分配,验证了负载均衡效果。然而,这种方法的一个缺点是nginx必须作为系统架构的第一入口,以确保能正确获取客户端IP。

#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {

    include       mime.types;
    default_type  application/octet-stream;


    sendfile        on;
    keepalive_timeout  65;

    upstream webSockerNginx {
    ip_hash;  
    server 172.16.55.62:8081 weight=10;
    server 192.168.8.23:8083 weight=10;
    }

    server {
        listen       8080;
        server_name  webSockerNginxServer;


        location / {
        #支持websocket
        proxy_http_version 1.1;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection  "upgrade";
        #解决 前端403问题
        proxy_set_header  Origin "";

        #解决IP问题
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        #解决超时时间
        proxy_connect_timeout 3600s; #配置点1
        proxy_read_timeout 3600s; #配置点2,如果没效,可以考虑这个时间配置长一点
        proxy_send_timeout 3600s; #配置点3
        proxy_pass  http://webSockerNginx;

        }

        
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

    }


}


后端代码

springboot+spring-websocket demo下载

https://download.youkuaiyun.com/download/whiteforever/10630375

 

下载项目后在不同的网段分别部署该demo项目 (因为ip_hash是根据前三位加密的 所以必须保持 xxx.xxx.xxx.aaa 前三位xxx不一样,如果前三位都一样,websocket会连接到同一个后台

项目中根据环境变量配置系统变量

spring.profiles.active=dev8081  部署在window ip172.16.55.62

spring.profiles.active=dev8082 部署在linux ip 192.168.8.23

把项目打成可执行jar包分别部署在不同IP网段的服务器后启动

启动nginx

访问在window访问websocket页面 然后查看其中一个服务器的日志

http://172.16.55.62:8080/html/user.html

显示该websocket已经连上了linux启动的服务器

 

在linux打开websocket连接 linux 命令如下

curl --include      --no-buffer      --header "Connection: Upgrade"      --header "Upgrade: websocket"      --header "Host: example.com:80"      --header "Origin: http://example.com:80"      --header "Sec-WebSocket-Key: SGVsbG8sIHdvcmxkIQ=="      --header "Sec-WebSocket-Version: 13"   http://172.16.55.62:8080/websocket/socketServer

发现linux上打开的websocket连接到了windows启动的服务器上

至此 websocket通过nginx做负载均衡的效果已经实现

 

注:

此方案的缺点如下:

1。因为是通过nginx的ip_hash做的负载,所以nginx必须要作为架构的第一入口,否则可能会获取不到IP

 

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

white......

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值