All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.camel.model.loadbalancer.WeightedLoadBalancerDefinition Maven / Gradle / Ivy

There is a newer version: 4.6.0
Show newest version
/**
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apache.camel.model.loadbalancer;

import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlRootElement;

import org.apache.camel.model.LoadBalancerDefinition;
import org.apache.camel.processor.loadbalancer.LoadBalancer;
import org.apache.camel.processor.loadbalancer.WeightedLoadBalancer;
import org.apache.camel.processor.loadbalancer.WeightedRandomLoadBalancer;
import org.apache.camel.processor.loadbalancer.WeightedRoundRobinLoadBalancer;
import org.apache.camel.spi.Metadata;
import org.apache.camel.spi.RouteContext;
import org.apache.camel.util.ObjectHelper;

/**
 * Weighted load balancer
 *
 * The weighted load balancing policy allows you to specify a processing load distribution ratio for each server
 * with respect to others. In addition to the weight, endpoint selection is then further refined using
 * random distribution based on weight.
 */
@Metadata(label = "eip,routing,loadbalance")
@XmlRootElement(name = "weighted")
@XmlAccessorType(XmlAccessType.FIELD)
public class WeightedLoadBalancerDefinition extends LoadBalancerDefinition {
    @XmlAttribute
    private Boolean roundRobin;
    @XmlAttribute(required = true)
    private String distributionRatio;
    @XmlAttribute @Metadata(defaultValue = ",")
    private String distributionRatioDelimiter;

    public WeightedLoadBalancerDefinition() {
    }

    @Override
    protected LoadBalancer createLoadBalancer(RouteContext routeContext) {
        WeightedLoadBalancer loadBalancer;
        List distributionRatioList = new ArrayList();
        
        try {
            String[] ratios = distributionRatio.split(getDistributionRatioDelimiter());
            for (String ratio : ratios) {
                distributionRatioList.add(new Integer(ratio.trim()));
            }

            boolean isRoundRobin = getRoundRobin() != null && getRoundRobin();
            if (isRoundRobin) {
                loadBalancer = new WeightedRoundRobinLoadBalancer(distributionRatioList);
            } else {
                loadBalancer = new WeightedRandomLoadBalancer(distributionRatioList);
            }
        } catch (Exception e) {
            throw ObjectHelper.wrapRuntimeCamelException(e);
        }

        return loadBalancer;
    }

    public Boolean getRoundRobin() {
        return roundRobin;
    }

    /**
     * To enable round robin mode. By default the weighted distribution mode is used.
     * 

* The default value is false. */ public void setRoundRobin(Boolean roundRobin) { this.roundRobin = roundRobin; } public String getDistributionRatio() { return distributionRatio; } /** * The distribution ratio is a delimited String consisting on integer weights separated by delimiters for example "2,3,5". * The distributionRatio must match the number of endpoints and/or processors specified in the load balancer list. */ public void setDistributionRatio(String distributionRatio) { this.distributionRatio = distributionRatio; } public String getDistributionRatioDelimiter() { return distributionRatioDelimiter == null ? "," : distributionRatioDelimiter; } /** * Delimiter used to specify the distribution ratio. *

* The default value is , */ public void setDistributionRatioDelimiter(String distributionRatioDelimiter) { this.distributionRatioDelimiter = distributionRatioDelimiter; } @Override public String toString() { boolean isRoundRobin = getRoundRobin() != null && getRoundRobin(); if (isRoundRobin) { return "WeightedRoundRobinLoadBalancer[" + distributionRatio + "]"; } else { return "WeightedRandomLoadBalancer[" + distributionRatio + "]"; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy