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

netflix.ocelli.selectors.RoundRobinWeightSelector Maven / Gradle / Ivy

There is a newer version: 0.1.0-rc.2
Show newest version
package netflix.ocelli.selectors;

import java.util.Collections;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;

/**
 * Select the next element using round robin so that all server of a certain
 * weight are selected first before moving on to the next server.  
 * 
 * The weights are sorted such as that each cell in the array represents the
 * sum of the previous weight plus it's weight.
 * 
 * Worst case runtime complexity is O(log N)
 * 
 * @author elandau
 *
 */
public class RoundRobinWeightSelector implements WeightSelector {

    private AtomicInteger position = new AtomicInteger();
    
    @Override
    public Integer call(List weights, Integer count) {
        int next = position.incrementAndGet() % count;
        int pos = Collections.binarySearch(weights, next);
        if (pos >= 0) {
            return pos+1;
        }
        else {
            return -(pos) - 1;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy