系统架构使用Nginx做Web服务器,两台Tomcat做应用服务器,业务场景是前端通过ajax轮询请求后端获取其他群成员的在线离线状态,实现实时更新。部署负载均衡后,发现状态更新总是会延迟或卡住,猜测应该是ajax请求分配到两台机器上造成的,目前折中的方案就是在Nginx中配置ajax轮询请求的地址只分配到固定的一台机器上,nginx配置如下:
单独配置upstream。配置一个固定ip,然后配置location规则:
upstream ajaxreq{
server 192.168.60.139:18080;
}
location ~ ^/jsp/userSessionStateSyn {
# include enable-cors.conf;
proxy_set_header Host $host:$remote_port;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header X-Real-Port $remote_port;
proxy_pass http://ajaxreq;
}
这样就配置了所有到包含/jsp/userSessionStateSyn的路径的请求都分配到192.168.60.139这台机器的Tomcat上