io.hekate.rpc.RpcClientConfig Maven / Gradle / Ivy
/*
* Copyright 2022 The Hekate Project
*
* The Hekate Project 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 io.hekate.rpc;
import io.hekate.messaging.retry.GenericRetryConfigurer;
import io.hekate.partition.Partition;
import io.hekate.partition.RendezvousHashMapper;
import io.hekate.util.format.ToString;
import java.util.Set;
import java.util.concurrent.TimeUnit;
/**
* RPC client configuration.
*
*
* This class provides support for pre-configuring some of the {@link RpcClientBuilder}'s options. When {@link RpcClientBuilder} is
* requested from the {@link RpcService} it first searches for an existing configuration by using the following rules:
*
*
*
* - if {@link RpcService#clientFor(Class)} method is used then it will search for an instance of {@link RpcClientConfig} that has the
* same {@link #setRpcInterface(Class) RPC interface} and a {@code null} {@link #setTag(String) tag}
* - if {@link RpcService#clientFor(Class, String)} method is used then it will search for an instance of {@link RpcClientConfig} that
* has the same {@link #setRpcInterface(Class) RPC interface} and the same {@link #setTag(String) tag} value
*
*
*
* If such {@link RpcClientConfig} instance is found then its options will be applied to the {@link RpcClientBuilder}.
*
*
*
* For more details about the Remote Procedure Call API and its capabilities please see the documentation of the {@link RpcService}
* interface.
*
*
* @see RpcService#clientFor(Class)
* @see RpcService#clientFor(Class, String)
*/
public class RpcClientConfig {
private Class> rpcInterface;
private String tag;
private RpcLoadBalancer loadBalancer;
private int partitions = RendezvousHashMapper.DEFAULT_PARTITIONS;
private int backupNodes;
private long timeout;
private GenericRetryConfigurer retryPolicy;
/**
* Returns the RPC interface (see {@link #setRpcInterface(Class)}).
*
* @return RPC interface.
*/
public Class> getRpcInterface() {
return rpcInterface;
}
/**
* Sets the RPC interface.
*
*
* The specified interface must be public and must be annotated with {@link Rpc}.
*
*
* @param rpcInterface RPC interface.
*/
public void setRpcInterface(Class> rpcInterface) {
this.rpcInterface = rpcInterface;
}
/**
* Fluent-style version of {@link #setRpcInterface(Class)}.
*
* @param rpcInterface RPC interface.
*
* @return This instance.
*/
public RpcClientConfig withRpcInterface(Class> rpcInterface) {
setRpcInterface(rpcInterface);
return this;
}
/**
* Returns the RPC interface tag (see {@link #setTag(String)}).
*
* @return RPC interface tag.
*/
public String getTag() {
return tag;
}
/**
* Sets the RPC interface tag.
*
*
* If this parameter is specified then RPC requests will be submitted only to those servers that have the same tag set via {@link
* RpcServerConfig#setTags(Set)}. If this parameter is not specified then client will be able to submit RPC requests only to
* those servers that don't have any tags too.
*
*
* @param tag RPC interface tag.
*
* @see RpcServerConfig#setTags(Set)
* @see RpcService#clientFor(Class, String)
*/
public void setTag(String tag) {
this.tag = tag;
}
/**
* Fluent-style version of {@link #setTag(String)}.
*
* @param tag RPC interface tag.
*
* @return This instance.
*/
public RpcClientConfig withTag(String tag) {
setTag(tag);
return this;
}
/**
* Returns the RPC load balancer (see {@link #setLoadBalancer(RpcLoadBalancer)}).
*
* @return RPC load balancer.
*/
public RpcLoadBalancer getLoadBalancer() {
return loadBalancer;
}
/**
* Sets the RPC load balancer.
*
* @param loadBalancer RPC load balancer.
*/
public void setLoadBalancer(RpcLoadBalancer loadBalancer) {
this.loadBalancer = loadBalancer;
}
/**
* Fluent-style version of {@link #setLoadBalancer(RpcLoadBalancer)}.
*
* @param loadBalancer RPC load balancer.
*
* @return This instance.
*
* @see RpcClientBuilder#withLoadBalancer(RpcLoadBalancer)
*/
public RpcClientConfig withLoadBalancer(RpcLoadBalancer loadBalancer) {
setLoadBalancer(loadBalancer);
return this;
}
/**
* Returns the total amount of partitions that should be managed by the RPC client's {@link RpcClientBuilder#partitions() partition
* mapper} (see {@link #setPartitions(int)}).
*
* @return Total amount of partitions.
*/
public int getPartitions() {
return partitions;
}
/**
* Sets the total amount of partitions that should be managed by the RPC client's
* {@link RpcClientBuilder#partitions() partition mapper}.
*
*
* Value of this parameter must be above zero and must be a power of two.
* Default value is specified by {@link RendezvousHashMapper#DEFAULT_PARTITIONS}.
*
*
* @param partitions Total amount of partitions that should be managed by the RPC client's partition mapper (value must be a power of
* two).
*/
public void setPartitions(int partitions) {
this.partitions = partitions;
}
/**
* Fluent-style version of {@link #setPartitions(int)}.
*
* @param partitions Total amount of partitions that should be managed by the RPC client's partition mapper (value must be a power of
* two).
*
* @return This instance.
*/
public RpcClientConfig withPartitions(int partitions) {
setPartitions(partitions);
return this;
}
/**
* Returns the amount of backup nodes that should be assigned to each partition by the the RPC client's
* {@link RpcClientBuilder#partitions() partition mapper} (see {@link #setBackupNodes(int)}).
*
* @return Amount of backup nodes.
*/
public int getBackupNodes() {
return backupNodes;
}
/**
* Sets the amount of backup nodes that should be assigned to each partition by the the RPC client's
* {@link RpcClientBuilder#partitions() partition mapper}.
*
*
* If value of this parameter is zero then the RPC client's mapper will not manage {@link Partition#backupNodes() backup nodes}.
* If value of this parameter is negative then all available cluster nodes will be used as {@link Partition#backupNodes() backup nodes}.
*
*
*
* Default value of this parameter is 0 (i.e. backup nodes management is disabled).
*
*
* @param backupNodes Amount of backup nodes that should be assigned to each partition of the RPC client's partition mapper.
*/
public void setBackupNodes(int backupNodes) {
this.backupNodes = backupNodes;
}
/**
* Fluent-style version of {@link #setBackupNodes(int)}.
*
* @param backupNodes Amount of backup nodes that should be assigned to each partition of the RPC client's partition mapper.
*
* @return This instance.
*/
public RpcClientConfig withBackupNodes(int backupNodes) {
setBackupNodes(backupNodes);
return this;
}
/**
* Returns the timeout in milliseconds (see {@link #setTimeout(long)}).
*
* @return Timeout in milliseconds.
*/
public long getTimeout() {
return timeout;
}
/**
* Sets the RPC timeout in milliseconds.
*
*
* If the RPC operation can not be completed at the specified timeout then such operation will end up an error.
* Specifying a negative or zero value disables the timeout check.
*
*
* @param timeout RPC timeout in milliseconds.
*
* @see RpcClientBuilder#withTimeout(long, TimeUnit)
*/
public void setTimeout(long timeout) {
this.timeout = timeout;
}
/**
* Fluent-style version of {@link #setTimeout(long)}.
*
* @param timeout RPC timeout in milliseconds.
*
* @return This instance.
*/
public RpcClientConfig withTimeout(long timeout) {
setTimeout(timeout);
return this;
}
/**
* Returns the generic retry policy (see {@link #setRetryPolicy(GenericRetryConfigurer)}).
*
* @return Generic retry policy.
*/
public GenericRetryConfigurer getRetryPolicy() {
return retryPolicy;
}
/**
* Sets the generic retry policy.
*
*
* Notice:
* The specified retry policy will be applied only to those RPC methods that are explicitly marked with the {@link RpcRetry} annotation.
* Options that are defined in the annotation's attributes have higher priority over this policy.
*
*
*
* Alternatively the generic retry policy can be specified at the RPC client construction time via the
* {@link RpcClientBuilder#withRetryPolicy(GenericRetryConfigurer)} method.
*
*
* @param retryPolicy Generic retry policy.
*
* @see RpcRetry
*/
public void setRetryPolicy(GenericRetryConfigurer retryPolicy) {
this.retryPolicy = retryPolicy;
}
/**
* Fluent-style version of {@link #setRetryPolicy(GenericRetryConfigurer)}.
*
* @param retryPolicy Generic retry policy.
*
* @return This instance.
*/
public RpcClientConfig withRetryPolicy(GenericRetryConfigurer retryPolicy) {
setRetryPolicy(retryPolicy);
return this;
}
@Override
public String toString() {
return ToString.format(this);
}
}