LoadBalancingStrategy.java
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.messaging.eventhubs;
/**
* The strategy used by event processor for load balancing the partition ownership to distribute the event processing
* work with other processor instances.
*
* @see EventProcessorClientBuilder#loadBalancingStrategy(LoadBalancingStrategy)
*/
public enum LoadBalancingStrategy {
/**
* The event processor will use a steady approach to claim ownership of partitions and slowly trend
* towards a stable state where all active processors will have an even distribution of Event Hub partitions.
* This strategy may take longer to settle into a balanced partition distribution among active processor
* instances. This strategy is geared towards minimizing ownership contention and reducing the need to transfer
* ownership frequently, especially when multiple instances are initialized together, until a stable state is
* reached.
*/
BALANCED,
/**
* The event processor will attempt to claim its fair share of partition ownership greedily. This enables event
* processing of all partitions to start/resume quickly when there is an imbalance detected by the processor.
* This may result in ownership of partitions frequently changing when multiple instances are starting up
* but will eventually converge to a stable state.
*/
GREEDY;
}