All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.microsoft.azure.eventhubs.PartitionReceiver Maven / Gradle / Ivy

There is a newer version: 3.3.0
Show newest version
/*
 * Copyright (c) Microsoft. All rights reserved.
 * Licensed under the MIT license. See LICENSE file in the project root for full license information.
 */
package com.microsoft.azure.eventhubs;

import com.microsoft.azure.eventhubs.impl.ExceptionUtil;

import java.time.Duration;
import java.util.concurrent.CompletableFuture;

/**
 * This is a logical representation of receiving from a EventHub partition.
 * 

* A {@link PartitionReceiver} is tied to a ConsumerGroup + EventHub Partition combination. *

    *
  • If an epoch based {@link PartitionReceiver} (i.e., PartitionReceiver.getEpoch != 0) is created, EventHubs service will guarantee only 1 active receiver exists per ConsumerGroup + Partition combo. * This is the recommended approach to create a {@link PartitionReceiver}. *
  • Multiple receivers per ConsumerGroup + Partition combo can be created using non-epoch receivers. *
* * @see EventHubClient#createReceiver * @see EventHubClient#createEpochReceiver */ public interface PartitionReceiver { int MINIMUM_PREFETCH_COUNT = 10; int DEFAULT_PREFETCH_COUNT = 999; long NULL_EPOCH = 0; /** * Get EventHubs partition identifier. * * @return The identifier representing the partition from which this receiver is fetching data */ String getPartitionId(); /** * Get Prefetch Count configured on the Receiver. * * @return the upper limit of events this receiver will actively receive regardless of whether a receive operation is pending. * @see #setPrefetchCount */ int getPrefetchCount(); /** * Set the number of events that can be pre-fetched and cached at the {@link PartitionReceiver}. *

By default the value is 300 * * @param prefetchCount the number of events to pre-fetch. value must be between 10 and 999. Default is 300. * @throws EventHubException if setting prefetchCount encounters error */ void setPrefetchCount(final int prefetchCount) throws EventHubException; Duration getReceiveTimeout(); void setReceiveTimeout(Duration value); /** * Get the epoch value that this receiver is currently using for partition ownership. *

* A value of 0 means this receiver is not an epoch-based receiver. * * @return the epoch value that this receiver is currently using for partition ownership. */ long getEpoch(); /** * Gets the temporal {@link ReceiverRuntimeInformation} for this EventHub partition. * In general, this information is a representation of, where this {@link PartitionReceiver}'s end of stream is, * at the time {@link ReceiverRuntimeInformation#getRetrievalTime()}. * * @return receiver runtime information */ ReceiverRuntimeInformation getRuntimeInformation(); /** * Synchronous version of {@link #receive}. * * @param maxEventCount maximum number of {@link EventData}'s that this call should return * @return Batch of {@link EventData}'s from the partition on which this receiver is created. Returns 'null' if no {@link EventData} is present. * @throws EventHubException if ServiceBus client encountered any unrecoverable/non-transient problems during {@link #receive} */ default Iterable receiveSync(final int maxEventCount) throws EventHubException { return ExceptionUtil.sync(() -> this.receive(maxEventCount).get()); } /** * Receive a batch of {@link EventData}'s from an EventHub partition *

* Sample code (sample uses sync version of the api but concept are identical): *

     * EventHubClient client = EventHubClient.createSync("__connection__");
     * PartitionReceiver receiver = client.createPartitionReceiverSync("ConsumerGroup1", "1");
     * Iterable{@literal<}EventData{@literal>} receivedEvents = receiver.receiveSync();
     *
     * while (true)
     * {
     *     int batchSize = 0;
     *     if (receivedEvents != null)
     *     {
     *         for(EventData receivedEvent: receivedEvents)
     *         {
     *             System.out.println(String.format("Message Payload: %s", new String(receivedEvent.getBytes(), Charset.defaultCharset())));
     *             System.out.println(String.format("Offset: %s, SeqNo: %s, EnqueueTime: %s",
     *                 receivedEvent.getSystemProperties().getOffset(),
     *                 receivedEvent.getSystemProperties().getSequenceNumber(),
     *                 receivedEvent.getSystemProperties().getEnqueuedTime()));
     *             batchSize++;
     *         }
     *     }
     *
     *     System.out.println(String.format("ReceivedBatch Size: %s", batchSize));
     *     receivedEvents = receiver.receiveSync();
     * }
     * 
* * @param maxEventCount maximum number of {@link EventData}'s that this call should return * @return A completableFuture that will yield a batch of {@link EventData}'s from the partition on which this receiver is created. Returns 'null' if no {@link EventData} is present. */ CompletableFuture> receive(final int maxEventCount); /** * Register a receive handler that will be called when an event is available. A * {@link PartitionReceiveHandler} is a handler that allows user to specify a callback * for event processing and error handling in a receive pump model. * * @param receiveHandler An implementation of {@link PartitionReceiveHandler}. Setting this handler to null will stop the receive pump. * @return A completableFuture which sets receiveHandler */ CompletableFuture setReceiveHandler(final PartitionReceiveHandler receiveHandler); /** * Register a receive handler that will be called when an event is available. A * {@link PartitionReceiveHandler} is a handler that allows user to specify a callback * for event processing and error handling in a receive pump model. * * @param receiveHandler An implementation of {@link PartitionReceiveHandler} * @param invokeWhenNoEvents flag to indicate whether the {@link PartitionReceiveHandler#onReceive(Iterable)} should be invoked when the receive call times out * @return A completableFuture which sets receiveHandler */ CompletableFuture setReceiveHandler(final PartitionReceiveHandler receiveHandler, final boolean invokeWhenNoEvents); CompletableFuture close(); void closeSync() throws EventHubException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy