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

com.rabbitmq.stream.StreamStats Maven / Gradle / Ivy

Go to download

The RabbitMQ Stream Java client library allows Java applications to interface with RabbitMQ Stream.

The newest version!
// Copyright (c) 2020-2023 Broadcom. All Rights Reserved.
// The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
//
// This software, the RabbitMQ Stream Java client library, is dual-licensed under the
// Mozilla Public License 2.0 ("MPL"), and the Apache License version 2 ("ASL").
// For the MPL, please see LICENSE-MPL-RabbitMQ. For the ASL,
// please see LICENSE-APACHE2.
//
// This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND,
// either express or implied. See the LICENSE file for specific language governing
// rights and limitations of this software.
//
// If you have any questions regarding licensing, please contact us at
// [email protected].
package com.rabbitmq.stream;

import com.rabbitmq.stream.MessageHandler.Context;

/**
 * Statistics on a stream.
 *
 * @see Environment#queryStreamStats(String)
 */
public interface StreamStats {

  /**
   * The first offset in the stream.
   *
   * @return first offset in the stream
   * @throws NoOffsetException if there is no first offset yet
   */
  long firstOffset();

  /**
   * The ID (offset) of the committed chunk (block of messages) in the stream.
   *
   * 

It is the offset of the first message in the last chunk confirmed by a quorum of the stream * cluster members (leader and replicas). * *

The committed chunk ID is a good indication of what the last offset of a stream can be at a * given time. The value can be stale as soon as the application reads it though, as the committed * chunk ID for a stream that is published to changes all the time. * * @return committed offset in this stream * @see Context#committedChunkId() * @throws NoOffsetException if there is no committed chunk yet */ long committedChunkId(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy