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 = 1; int DEFAULT_PREFETCH_COUNT = 500; int MAXIMUM_PREFETCH_COUNT = 2000; long NULL_EPOCH = 0; /** * Get EventHubs partition identifier. * * @return The identifier representing the partition from which this receiver is fetching data */ String getPartitionId(); 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()}. *

This value will not be populated, unless the knob {@link ReceiverOptions#setReceiverRuntimeMetricEnabled(boolean)} is set. * This value will be refreshed every time an {@link EventData} is consumed from {@link PartitionReceiver}. * For ex: if no events have been consumed, then this value is not populated. * * @return receiver runtime information */ ReceiverRuntimeInformation getRuntimeInformation(); /** * Get the {@link EventPosition} that corresponds to an {@link EventData} which was returned last by the receiver. *

This value will not be populated, unless the knob {@link ReceiverOptions#setReceiverRuntimeMetricEnabled(boolean)} is set. * Note that EventPosition object is initialized using SequenceNumber and other parameters are not set and get will return null. * * @return the EventPosition object. */ EventPosition getEventPosition(); /** * 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