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

被折叠的 条评论
为什么被折叠?



