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

org.apache.pulsar.client.api.Reader Maven / Gradle / Ivy

There is a newer version: 4.0.0.10
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF 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 org.apache.pulsar.client.api;

import java.io.Closeable;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.TimeUnit;
import java.util.function.Function;
import org.apache.pulsar.common.classification.InterfaceAudience;
import org.apache.pulsar.common.classification.InterfaceStability;

/**
 * A Reader can be used to scan through all the messages currently available in a topic.
 */
@InterfaceAudience.Public
@InterfaceStability.Stable
public interface Reader extends Closeable {

    /**
     * @return the topic from which this reader is reading from
     */
    String getTopic();

    /**
     * Read the next message in the topic.
     *
     * 

This method will block until a message is available. * * @return the next message * @throws PulsarClientException */ Message readNext() throws PulsarClientException; /** * Read the next message in the topic waiting for a maximum time. * *

Returns null if no message is received before the timeout. * * @return the next message(Could be null if none received in time) * @throws PulsarClientException */ Message readNext(int timeout, TimeUnit unit) throws PulsarClientException; /** * Read asynchronously the next message in the topic. * *

{@code readNextAsync()} should be called subsequently once returned {@code CompletableFuture} gets complete * with received message. Else it creates backlog of receive requests in the application. * *

The returned future can be cancelled before completion by calling {@code .cancel(false)} * ({@link CompletableFuture#cancel(boolean)}) to remove it from the the backlog of receive requests. Another * choice for ensuring a proper clean up of the returned future is to use the CompletableFuture.orTimeout method * which is available on JDK9+. That would remove it from the backlog of receive requests if receiving exceeds * the timeout. * * @return a future that will yield a message (when it's available) or {@link PulsarClientException} if the reader * is already closed. */ CompletableFuture> readNextAsync(); /** * Asynchronously close the reader and stop the broker to push more messages. * * @return a future that can be used to track the completion of the operation */ CompletableFuture closeAsync(); /** * Return true if the topic was terminated and this reader has reached the end of the topic. * *

Note that this only applies to a "terminated" topic (where the topic is "sealed" and no * more messages can be published) and not just that the reader is simply caught up with * the publishers. Use {@link #hasMessageAvailable()} to check for for that. */ boolean hasReachedEndOfTopic(); /** * Check if there is any message available to read from the current position. * *

This check can be used by an application to scan through a topic and stop * when the reader reaches the current last published message. For example: * *

{@code
     * while (reader.hasMessageAvailable()) {
     *     Message msg = reader.readNext();
     *     // Do something
     * }
     *
     * // Done reading
     * }
* *

Note that this call might be blocking (see {@link #hasMessageAvailableAsync()} for async version) and * that even if this call returns true, that will not guarantee that a subsequent call to {@link #readNext()} * will not block. * * @return true if the are messages available to be read, false otherwise * @throws PulsarClientException if there was any error in the operation */ boolean hasMessageAvailable() throws PulsarClientException; /** * Asynchronously check if there is any message available to read from the current position. * *

This check can be used by an application to scan through a topic and stop when the reader reaches the current * last published message. * * @return a future that will yield true if the are messages available to be read, false otherwise, or a * {@link PulsarClientException} if there was any error in the operation */ CompletableFuture hasMessageAvailableAsync(); /** * @return Whether the reader is connected to the broker */ boolean isConnected(); /** * Reset the subscription associated with this reader to a specific message id. * *

The message id can either be a specific message or represent the first or last messages in the topic. *

    *
  • MessageId.earliest : Reset the reader on the earliest message available in the topic *
  • MessageId.latest : Reset the reader on the latest message in the topic *
* *

Note: this operation can only be done on non-partitioned topics. For these, one can rather perform * the seek() on the individual partitions. * * @param messageId the message id where to reposition the reader */ void seek(MessageId messageId) throws PulsarClientException; /** * Reset the subscription associated with this reader to a specific message publish time. * *

Note: this operation can only be done on non-partitioned topics. For these, one can rather perform * the seek() on the individual partitions. * * @param timestamp the message publish time where to reposition the reader * The timestamp format should be Unix time in milliseconds. */ void seek(long timestamp) throws PulsarClientException; /** * Reset the subscription associated with this consumer to a specific message ID or message publish time. *

* The Function input is topic+partition. It returns only timestamp or MessageId. *

* The return value is the seek position/timestamp of the current partition. * Exception is thrown if other object types are returned. *

* If returns null, the current partition will not do any processing. * Exception in a partition may affect other partitions. * @param function * @throws PulsarClientException */ void seek(Function function) throws PulsarClientException; /** * Reset the subscription associated with this consumer to a specific message ID * or message publish time asynchronously. *

* The Function input is topic+partition. It returns only timestamp or MessageId. *

* The return value is the seek position/timestamp of the current partition. * Exception is thrown if other object types are returned. *

* If returns null, the current partition will not do any processing. * Exception in a partition may affect other partitions. * @param function * @return */ CompletableFuture seekAsync(Function function); /** * Reset the subscription associated with this reader to a specific message id. * *

The message id can either be a specific message or represent the first or last messages in the topic. *

    *
  • MessageId.earliest : Reset the reader on the earliest message available in the topic *
  • MessageId.latest : Reset the reader on the latest message in the topic *
* *

Note: this operation can only be done on non-partitioned topics. For these, one can rather perform * the seek() on the individual partitions. * * @param messageId the message id where to position the reader * @return a future to track the completion of the seek operation */ CompletableFuture seekAsync(MessageId messageId); /** * Reset the subscription associated with this reader to a specific message publish time. * *

Note: this operation can only be done on non-partitioned topics. For these, one can rather perform * the seek() on the individual partitions. * * @param timestamp * the message publish time where to position the reader * The timestamp format should be Unix time in milliseconds. * @return a future to track the completion of the seek operation */ CompletableFuture seekAsync(long timestamp); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy