Jagger
 All Classes Namespaces Files Functions Variables Enumerator Groups Pages
PairSupplierFactoryLoadBalancer.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 org.slf4j.Logger;
24 import org.slf4j.LoggerFactory;
25 
29 public abstract class PairSupplierFactoryLoadBalancer<Q, E> extends QueryPoolLoadBalancer<Q, E> {
30 
31  private final static Logger log = LoggerFactory.getLogger(PairSupplierFactoryLoadBalancer.class);
32  private final PairSupplierFactory<Q, E> pairSupplierFactory;
33  private volatile PairSupplier<Q, E> pairSupplier;
34 
35  protected PairSupplierFactoryLoadBalancer(PairSupplierFactory<Q, E> pairSupplierFactory) {
36  this.pairSupplierFactory = pairSupplierFactory;
37  }
38 
39  protected PairSupplier<Q, E> getPairSupplier() {
40  return pairSupplier;
41  }
42 
43  @Override
44  public void init() {
45  synchronized (lock) {
46  if (initialized) {
47  log.debug("already initialized. returning...");
48  return;
49  }
50  super.init();
51 
52  pairSupplier = pairSupplierFactory.create(queryProvider, endpointProvider);
53  log.info("{} pairs in total to balance", pairSupplier.size());
54  }
55  }
56 }