[沧海拾遗]nginx反向代理和负载均衡

今天收到一个需求,集群A上的一个页面中要调用B集群的一个ajax接口,然后这个ajax接口需要从cookie中取到session id去取session信息,但是这个cookie在调用集群B的登录时会写到集群B的域名下,因此集群A上的页面无法取到。而A、B两个集群都是nginx+tomcat的架构。想了一下,觉得可以通过nginx的反向代理和负载均衡来解决这个问题。

如果A集群页面url中的域名替换成B集群的域名,然后能够正常访问的话,这个问题就解决。那么就可以使用反向代理来将B集群的这个uri反向代理到A集群的tomcat中。假设页面的uri为xxx/test.html,A集群中有一台服务器的ip为ipa,tomcat的端口为7001,然后B集群的nginx就可以加入如下的配置做一个反向代理就能拿到正常页面:

location /xxx/test.html {
    proxy_pass   http://ipa:7001;
}

这样就可以将所有从B集群访问到xxx/test.html的请求,都交由A集群的ipa这台机器来返回页面数据了。但是这样的话,如果所有的B集群都配置成ipa的话,显然所有的请求都会流向ipa,ipa的压力就会很大,最好的作法是能够做一下负载均衡,让这些请求能够均摊到所有A集群的机器上,这里就要用到nginx的负载均衡配置。

upstream f5config { 
    server ipa:7001 weight=5; ##weight=5表示设置服务器的权重
    server ipb:7001 weight=5;
}

然后将上面的反向代理的配置改为如下:

location /xxx/test.html {
    proxy_pass   http://f5config;
}

然后所有的请求就能按照权重来代理到指定的机器上来执行了。

你可能感兴趣的:(java)