负载平衡在两场战争中运行的tomcat应用程序

时间:2012-12-21 09:26:32

标签: java apache tomcat load-balancing

我的应用程序(部署在tomcat中)有两个战争,一个客户端(比如A)和一个服务器(比如说B)。它们都部署在同一个jvm中,并通过Web服务进行通信。现在,为了使应用程序可扩展,我希望将其集群并部署在多个节点中。以下是apache服务器中的负载均衡器配置。

<Proxy balancer://mycluster stickysession=JSESSIONID>
BalancerMember ajp://127.0.0.1:8009 min=10 max=100 route=jvm1 loadfactor=1
BalancerMember ajp://127.0.0.1:8019 min=20 max=200 route=jvm2 loadfactor=1
</Proxy>

ProxyPass /A balancer://mycluster/A
ProxyPass /B balancer://mycluster/B

在我的客户端应用程序中,提供了服务器URL,如下所示

server.url=http://localhost/B/myservice/

我的意图是,任何到达节点上的Web应用程序A的请求都应该在同一节点上的Web应用程序B中处理。但是对于当前的配置,它没有给出预期的结果。在web应用程序中处理的请求jvm1上的请求转到jvm2上的Web应用程序B,反之亦然。请让我知道我在这里缺少什么,我怎么能摆脱这个问题

1 个答案:

答案 0 :(得分:1)

您观察到的行为似乎是合理的:您向Apache负载均衡器发送请求,并将其路由到其中一个节点。如果我理解您的方案正确,您希望强制将请求(由您的Web应用程序启动)路由到正确的节点。我可以想到两种方法来实现这个目标:

  1. 我认为到达网络应用A的初始请求来自拥有会话的用户。如果您已在Tomcat中配置了粘性会话,则可以重用该用户的会话cookie并将其与您的Web服务请求一起发送。这样,负载均衡器将决定将请求路由到与为您带来cookie的原始请求相同的节点。但是,从您调用Web服务的位置访问cookie可能不太可行。
  2. 处理内部请求并不是负载均衡器的工作。那么为什么要使用呢?您可以为Tomcat配置添加常规HTTP连接器,并将其用于Web服务请求。因此,您可以绕过负载平衡,在这种情况下,只会增加通信的不必要的延迟和开销。缺点是:您可能需要对IP进行硬编码才能调用。
  3. 顺便说一句:您的配置看起来好像两台节点负载均衡器都在一台机器上运行。当然可以吗?