Jagger
 All Classes Namespaces Files Functions Variables Enumerator Groups Pages
QueryPoolLoadBalancer.java
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2010-2012 Grid Dynamics Consulting Services, Inc, All Rights Reserved
3  * http://www.griddynamics.com
4  *
5  * This library is free software; you can redistribute it and/or modify it under the terms of
6  * the Apache License; either
7  * version 2.0 of the License, or any later version.
8  *
9  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
10  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
11  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
12  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
13  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
14  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
15  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
16  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
17  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
18  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
19  */
20 
21 package com.griddynamics.jagger.invoker;
22 
23 import com.griddynamics.jagger.util.Pair;
24 import java.util.Iterator;
25 
34 public abstract class QueryPoolLoadBalancer<Q, E> implements LoadBalancer<Q, E> {
35 
36  protected Iterable<Q> queryProvider;
37  protected Iterable<E> endpointProvider;
38 
40  }
41 
42  public QueryPoolLoadBalancer(Iterable<Q> queryProvider, Iterable<E> endpointProvider){
43  this.queryProvider = queryProvider;
44  this.endpointProvider = endpointProvider;
45  }
46 
47  public void setQueryProvider(Iterable<Q> queryProvider){
48  this.queryProvider = queryProvider;
49  }
50 
51  public void setEndpointProvider(Iterable<E> endpointProvider){
52  this.endpointProvider = endpointProvider;
53  }
54 
55  @Override
56  public final Iterator<Pair<Q, E>> iterator() {
57  return provide();
58  }
59 
60  @Override
61  public int endpointSize() {
62  return getIterableSize(endpointProvider);
63  }
64 
65  @Override
66  public int querySize() {
67  return getIterableSize(queryProvider);
68  }
69 
70  public int getIterableSize(Iterable iterable){
71  if (iterable == null)
72  return 0;
73 
74  Iterator<Q> iterator = iterable.iterator();
75  int size = 0;
76  while (iterator.hasNext()){
77  iterator.next();
78  size++;
79  }
80  return size;
81  }
82 }