pub struct RemoteLogSegmentMetadata { /* private fields */ }Expand description
Metadata describing one segment stored (or being stored) in the remote tier.
Implementations§
Source§impl RemoteLogSegmentMetadata
impl RemoteLogSegmentMetadata
Sourcepub fn new(
remote_log_segment_id: RemoteLogSegmentId,
start_offset: i64,
end_offset: i64,
max_timestamp_ms: i64,
broker_id: i32,
event_timestamp_ms: i64,
segment_size_in_bytes: i32,
state: RemoteLogSegmentState,
segment_leader_epochs: BTreeMap<i32, i64>,
) -> Result<Self, RemoteStorageError>
pub fn new( remote_log_segment_id: RemoteLogSegmentId, start_offset: i64, end_offset: i64, max_timestamp_ms: i64, broker_id: i32, event_timestamp_ms: i64, segment_size_in_bytes: i32, state: RemoteLogSegmentState, segment_leader_epochs: BTreeMap<i32, i64>, ) -> Result<Self, RemoteStorageError>
Construct a RemoteLogSegmentMetadata.
§Errors
Returns RemoteStorageError::InvalidArgument when
segment_leader_epochs is empty, end_offset < start_offset, or
segment_size_in_bytes < 0.
Sourcepub fn with_update(
&self,
update: &RemoteLogSegmentMetadataUpdate,
) -> Result<Self, RemoteStorageError>
pub fn with_update( &self, update: &RemoteLogSegmentMetadataUpdate, ) -> Result<Self, RemoteStorageError>
Apply a RemoteLogSegmentMetadataUpdate, returning the updated
copy. The update advances state, refreshes event_timestamp_ms
and broker_id, and replaces custom_metadata when the update
carries Some.
§Errors
Returns RemoteStorageError::InvalidArgument if the update’s
segment id does not match, or
RemoteStorageError::InvalidSegmentTransition if the state change
is not permitted from the current state.
Sourcepub fn remote_log_segment_id(&self) -> &RemoteLogSegmentId
pub fn remote_log_segment_id(&self) -> &RemoteLogSegmentId
The segment’s unique id.
Sourcepub fn start_offset(&self) -> i64
pub fn start_offset(&self) -> i64
First offset (inclusive) covered by this segment.
Sourcepub fn end_offset(&self) -> i64
pub fn end_offset(&self) -> i64
Last offset (inclusive) covered by this segment.
Sourcepub fn max_timestamp_ms(&self) -> i64
pub fn max_timestamp_ms(&self) -> i64
Highest record timestamp in this segment.
Sourcepub fn event_timestamp_ms(&self) -> i64
pub fn event_timestamp_ms(&self) -> i64
Wall-clock time the latest event for this segment was created.
Sourcepub fn segment_size_in_bytes(&self) -> i32
pub fn segment_size_in_bytes(&self) -> i32
Size of the .log data in bytes.
Sourcepub fn custom_metadata(&self) -> Option<&CustomMetadata>
pub fn custom_metadata(&self) -> Option<&CustomMetadata>
Opaque metadata the RemoteStorageManager
attached at copy time, if any.
Sourcepub fn state(&self) -> RemoteLogSegmentState
pub fn state(&self) -> RemoteLogSegmentState
Current lifecycle state.
Sourcepub fn segment_leader_epochs(&self) -> &BTreeMap<i32, i64>
pub fn segment_leader_epochs(&self) -> &BTreeMap<i32, i64>
Map of leader epoch → first offset that epoch contributed to this segment.
Sourcepub fn with_custom_metadata(self, custom: CustomMetadata) -> Self
pub fn with_custom_metadata(self, custom: CustomMetadata) -> Self
Attach custom metadata (builder-style; used by RSM copy paths that
produce a key before recording CopySegmentFinished).
Sourcepub fn txn_index_empty(&self) -> bool
pub fn txn_index_empty(&self) -> bool
true if the segment has no transaction index (KIP-405 txnIndexEmpty).
Defaults to false. Serialized as the JVM record’s tagged field (tag 0).
Sourcepub fn with_txn_index_empty(self, empty: bool) -> Self
pub fn with_txn_index_empty(self, empty: bool) -> Self
Builder-style setter for Self::txn_index_empty.
Trait Implementations§
Source§impl Clone for RemoteLogSegmentMetadata
impl Clone for RemoteLogSegmentMetadata
Source§fn clone(&self) -> RemoteLogSegmentMetadata
fn clone(&self) -> RemoteLogSegmentMetadata
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for RemoteLogSegmentMetadata
impl Debug for RemoteLogSegmentMetadata
impl Eq for RemoteLogSegmentMetadata
Source§impl PartialEq for RemoteLogSegmentMetadata
impl PartialEq for RemoteLogSegmentMetadata
Source§fn eq(&self, other: &RemoteLogSegmentMetadata) -> bool
fn eq(&self, other: &RemoteLogSegmentMetadata) -> bool
self and other values to be equal, and is used by ==.impl StructuralPartialEq for RemoteLogSegmentMetadata
Auto Trait Implementations§
impl Freeze for RemoteLogSegmentMetadata
impl RefUnwindSafe for RemoteLogSegmentMetadata
impl Send for RemoteLogSegmentMetadata
impl Sync for RemoteLogSegmentMetadata
impl Unpin for RemoteLogSegmentMetadata
impl UnsafeUnpin for RemoteLogSegmentMetadata
impl UnwindSafe for RemoteLogSegmentMetadata
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more