![JAR search and dependency download from the Maven repository](/logo.png)
com.qq.tars.client.rpc.loadbalance.DefaultLoadBalance Maven / Gradle / Ivy
/**
* Tencent is pleased to support the open source community by making Tars available.
*
* Copyright (C) 2016 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the BSD 3-Clause License (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* https://opensource.org/licenses/BSD-3-Clause
*
* 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 com.qq.tars.client.rpc.loadbalance;
import com.qq.tars.client.ServantProxyConfig;
import com.qq.tars.common.util.Constants;
import com.qq.tars.common.util.StringUtils;
import com.qq.tars.rpc.common.InvokeContext;
import com.qq.tars.rpc.common.Invoker;
import com.qq.tars.rpc.common.LoadBalance;
import com.qq.tars.rpc.common.exc.NoInvokerException;
import java.util.Collection;
public class DefaultLoadBalance implements LoadBalance {
private final RoundRobinLoadBalance roundRobinLoadBalance;
private final ServantProxyConfig config;
private volatile Collection> lastRefreshInvokers = null;
private volatile HashLoadBalance hashLoadBalance = null;
private final Object hashLoadBalanceLock = new Object();
private volatile ConsistentHashLoadBalance consistentHashLoadBalance = null;
private final Object consistentHashLoadBalanceLock = new Object();
public DefaultLoadBalance(ServantProxyConfig config) {
this.config = config;
this.roundRobinLoadBalance = new RoundRobinLoadBalance(config);
}
@Override
public Invoker select(InvokeContext invocation) throws NoInvokerException {
long hash = Math.abs(StringUtils.convertLong(invocation.getAttachment(Constants.TARS_HASH), 0));
long consistentHash = Math.abs(StringUtils.convertLong(invocation.getAttachment(Constants.TARS_CONSISTENT_HASH), 0));
if (consistentHash > 0) {
if (consistentHashLoadBalance == null) {
synchronized (consistentHashLoadBalanceLock) {
if (consistentHashLoadBalance == null) {
ConsistentHashLoadBalance tmp = new ConsistentHashLoadBalance(config);
tmp.refresh(lastRefreshInvokers);
consistentHashLoadBalance = tmp;
}
}
}
return consistentHashLoadBalance.select(invocation);
}
if (hash > 0) {
if (hashLoadBalance == null) {
synchronized (hashLoadBalanceLock) {
if (hashLoadBalance == null) {
HashLoadBalance tmp = new HashLoadBalance(config);
tmp.refresh(lastRefreshInvokers);
hashLoadBalance = tmp;
}
}
}
return hashLoadBalance.select(invocation);
}
return roundRobinLoadBalance.select(invocation);
}
@Override
public void refresh(Collection> invokers) {
lastRefreshInvokers = invokers;
synchronized (hashLoadBalanceLock) {
if (hashLoadBalance != null) {
hashLoadBalance.refresh(invokers);
}
}
synchronized (consistentHashLoadBalanceLock) {
if (consistentHashLoadBalance != null) {
consistentHashLoadBalance.refresh(invokers);
}
}
roundRobinLoadBalance.refresh(invokers);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy