Class RoundRobinLoadBalancer
- Namespace
- Steeltoe.Discovery.HttpClients.LoadBalancers
- Assembly
- Steeltoe.Discovery.HttpClients.dll
Returns service instances in round-robin fashion, optionally using distributed caching for determining the next instance.
public sealed class RoundRobinLoadBalancer : ILoadBalancer
- Inheritance
-
RoundRobinLoadBalancer
- Implements
- Inherited Members
Constructors
RoundRobinLoadBalancer(ServiceInstancesResolver, IDistributedCache?, DistributedCacheEntryOptions?, ILogger<RoundRobinLoadBalancer>)
Initializes a new instance of the RoundRobinLoadBalancer class.
public RoundRobinLoadBalancer(ServiceInstancesResolver serviceInstancesResolver, IDistributedCache? distributedCache, DistributedCacheEntryOptions? cacheEntryOptions, ILogger<RoundRobinLoadBalancer> logger)
Parameters
serviceInstancesResolverServiceInstancesResolverUsed to retrieve the available service instances.
distributedCacheIDistributedCacheFor caching the last-used instance.
cacheEntryOptionsDistributedCacheEntryOptionsConfiguration for
distributedCache.loggerILogger<RoundRobinLoadBalancer>Used for internal logging. Pass Instance to disable logging.
RoundRobinLoadBalancer(ServiceInstancesResolver, ILogger<RoundRobinLoadBalancer>)
Initializes a new instance of the RoundRobinLoadBalancer class.
public RoundRobinLoadBalancer(ServiceInstancesResolver serviceInstancesResolver, ILogger<RoundRobinLoadBalancer> logger)
Parameters
serviceInstancesResolverServiceInstancesResolverUsed to retrieve the available service instances.
loggerILogger<RoundRobinLoadBalancer>Used for internal logging. Pass Instance to disable logging.
Methods
ResolveServiceInstanceAsync(Uri, CancellationToken)
Evaluates a URI for a hostname that can be resolved into a service instance.
public Task<Uri> ResolveServiceInstanceAsync(Uri requestUri, CancellationToken cancellationToken)
Parameters
requestUriUriA URI containing a service name that can be resolved into one or more service instances.
cancellationTokenCancellationTokenThe token to monitor for cancellation requests.
Returns
- Task<Uri>
The original URI, with the scheme and service name replaced by the scheme, host and port of a service instance.
UpdateStatisticsAsync(Uri, Uri, TimeSpan?, Exception?, CancellationToken)
A mechanism for tracking statistics for service instances.
public Task UpdateStatisticsAsync(Uri requestUri, Uri serviceInstanceUri, TimeSpan? responseTime, Exception? exception, CancellationToken cancellationToken)
Parameters
requestUriUriThe original request URI.
serviceInstanceUriUriThe URI resolved by the load balancer.
responseTimeTimeSpan?The amount of time taken for a remote call to complete.
exceptionExceptionAny exception thrown during calls to a resolved service instance.
cancellationTokenCancellationTokenThe token to monitor for cancellation requests.