You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@synapse.apache.org by az...@apache.org on 2011/12/13 13:56:15 UTC

svn commit: r1213668 - /synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/core/axis2/ServiceLoadBalanceMembershipHandler.java

Author: azeez
Date: Tue Dec 13 12:56:15 2011
New Revision: 1213668

URL: http://svn.apache.org/viewvc?rev=1213668&view=rev
Log:
Dispatch *.foo.com sort of request hosts to clusters mapped to foo.com 


Modified:
    synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/core/axis2/ServiceLoadBalanceMembershipHandler.java

Modified: synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/core/axis2/ServiceLoadBalanceMembershipHandler.java
URL: http://svn.apache.org/viewvc/synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/core/axis2/ServiceLoadBalanceMembershipHandler.java?rev=1213668&r1=1213667&r2=1213668&view=diff
==============================================================================
--- synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/core/axis2/ServiceLoadBalanceMembershipHandler.java (original)
+++ synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/core/axis2/ServiceLoadBalanceMembershipHandler.java Tue Dec 13 12:56:15 2011
@@ -96,10 +96,7 @@ public class ServiceLoadBalanceMembershi
     }
 
     public Member getNextApplicationMember(String host) {
-        DomainAlgorithmContext domainAlgorithmContext = hostDomainAlgorithmContextMap.get(host);
-        if(domainAlgorithmContext == null) {
-            throw new SynapseException("Domain not found for host" + host);
-        }
+        DomainAlgorithmContext domainAlgorithmContext = getDomainAlgorithmContext(host);
         String lbDomain = domainAlgorithmContext.getDomain();
         LoadbalanceAlgorithm algorithm = domainAlgorithmContext.getAlgorithm();
         GroupManagementAgent groupMgtAgent = clusteringAgent.getGroupManagementAgent(lbDomain);
@@ -115,6 +112,19 @@ public class ServiceLoadBalanceMembershi
         return algorithm.getNextApplicationMember(context);
     }
 
+    private DomainAlgorithmContext getDomainAlgorithmContext(String host) {
+        DomainAlgorithmContext domainAlgorithmContext = hostDomainAlgorithmContextMap.get(host);
+        if(domainAlgorithmContext == null) {
+            int indexOfDot;
+            if ((indexOfDot = host.indexOf(".")) != -1) {
+                domainAlgorithmContext = getDomainAlgorithmContext(host.substring(indexOfDot + 1));
+            } else {
+                throw new SynapseException("Domain not found for host" + host);
+            }
+        }
+        return domainAlgorithmContext;
+    }
+
     public LoadbalanceAlgorithm getLoadbalanceAlgorithm() {
         return null;
     }