pub struct StreamCheckpoint {
pub id: u64,
pub epoch: u64,
pub source_sequences: HashMap<String, u64>,
pub sink_positions: HashMap<String, u64>,
pub watermarks: HashMap<String, i64>,
pub operator_states: HashMap<String, Vec<u8>>,
pub created_at: u64,
}Expand description
A point-in-time snapshot of streaming pipeline state.
Fields§
§id: u64Unique checkpoint identifier (monotonically increasing).
epoch: u64Epoch number.
source_sequences: HashMap<String, u64>Source name -> sequence number at checkpoint time.
sink_positions: HashMap<String, u64>Sink name -> position at checkpoint time.
watermarks: HashMap<String, i64>Source name -> watermark at checkpoint time.
operator_states: HashMap<String, Vec<u8>>Operator name -> opaque state bytes.
created_at: u64Timestamp when this checkpoint was created (millis since epoch).
Implementations§
Source§impl StreamCheckpoint
impl StreamCheckpoint
Sourcepub fn to_bytes(&self) -> Vec<u8> ⓘ
pub fn to_bytes(&self) -> Vec<u8> ⓘ
Serializes the checkpoint to bytes.
Format:
[version: 1][id: 8][epoch: 8][created_at: 8]
[num_sources: 4][ [name_len:4][name][seq:8] ... ]
[num_sinks: 4][ [name_len:4][name][pos:8] ... ]
[num_watermarks: 4][ [name_len:4][name][wm:8] ... ]
[num_ops: 4][ [name_len:4][name][data_len:4][data] ... ]Sourcepub fn from_bytes(data: &[u8]) -> Result<Self, CheckpointError>
pub fn from_bytes(data: &[u8]) -> Result<Self, CheckpointError>
Deserializes a checkpoint from bytes.
§Errors
Returns CheckpointError::IoError if the data is truncated, corrupted,
or uses an unsupported version.
Trait Implementations§
Source§impl Clone for StreamCheckpoint
impl Clone for StreamCheckpoint
Source§fn clone(&self) -> StreamCheckpoint
fn clone(&self) -> StreamCheckpoint
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreAuto Trait Implementations§
impl Freeze for StreamCheckpoint
impl RefUnwindSafe for StreamCheckpoint
impl Send for StreamCheckpoint
impl Sync for StreamCheckpoint
impl Unpin for StreamCheckpoint
impl UnwindSafe for StreamCheckpoint
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.