Struct mz_storage::source::reclock::ReclockFollower
source · pub struct ReclockFollower<FromTime: Timestamp, IntoTime: Timestamp + Lattice + Display> {
since: Antichain<IntoTime>,
pub inner: Rc<RefCell<ReclockFollowerInner<FromTime, IntoTime>>>,
}Expand description
A “follower” for the ReclockOperator, that maintains a trace based on the results of reclocking
and data from the source. It provides the reclock method, which produces messages with their
associated timestamps.
Shareable with .share()
Fields§
§since: Antichain<IntoTime>The since maintained by the local handle. This may be beyond the shared since
inner: Rc<RefCell<ReclockFollowerInner<FromTime, IntoTime>>>Implementations§
source§impl<FromTime, IntoTime> ReclockFollower<FromTime, IntoTime>
impl<FromTime, IntoTime> ReclockFollower<FromTime, IntoTime>
sourcepub fn new(as_of: Antichain<IntoTime>) -> Self
pub fn new(as_of: Antichain<IntoTime>) -> Self
Constructs a new ReclockFollower
pub fn source_upper(&self) -> Antichain<FromTime>
pub fn initialized(&self) -> bool
sourcepub fn push_trace_batch(&self, batch: ReclockBatch<FromTime, IntoTime>)
pub fn push_trace_batch(&self, batch: ReclockBatch<FromTime, IntoTime>)
Pushes a new trace batch into this ReclockFollower.
sourcepub fn reclock<'a, M: 'a>(
&'a self,
batch: impl IntoIterator<Item = (M, FromTime)> + 'a,
) -> impl Iterator<Item = (M, Result<IntoTime, ReclockError<FromTime>>)> + 'awhere
IntoTime: TotalOrder,
pub fn reclock<'a, M: 'a>(
&'a self,
batch: impl IntoIterator<Item = (M, FromTime)> + 'a,
) -> impl Iterator<Item = (M, Result<IntoTime, ReclockError<FromTime>>)> + 'awhere
IntoTime: TotalOrder,
Reclocks a batch of messages timestamped with FromTime and returns an iterator of
messages timestamped with IntoTime.
Each item of the resulting iterator will be associated with either the time it should be reclocked to or an error indicating that a reclocking decision could not be taken with the data that we have at hand.
This method is most efficient when the to be reclocked iterator presents data in contiguous
runs with the same FromTime.
sourcepub fn reclock_time(
&self,
src_ts: &FromTime,
) -> Result<Antichain<IntoTime>, ReclockError<FromTime>>
pub fn reclock_time( &self, src_ts: &FromTime, ) -> Result<Antichain<IntoTime>, ReclockError<FromTime>>
Reclocks a single FromTime timestamp into the IntoTime time domain.
sourcepub fn reclock_time_total(
&self,
src_ts: &FromTime,
) -> Result<IntoTime, ReclockError<FromTime>>where
IntoTime: TotalOrder,
pub fn reclock_time_total(
&self,
src_ts: &FromTime,
) -> Result<IntoTime, ReclockError<FromTime>>where
IntoTime: TotalOrder,
Reclocks a single FromTime timestamp into a totally ordered IntoTime time domain.
sourcepub fn reclock_frontier(
&self,
source_frontier: AntichainRef<'_, FromTime>,
) -> Result<Antichain<IntoTime>, ReclockError<FromTime>>
pub fn reclock_frontier( &self, source_frontier: AntichainRef<'_, FromTime>, ) -> Result<Antichain<IntoTime>, ReclockError<FromTime>>
Reclocks a FromTime frontier into a IntoTime frontier.
The conversion has the property that all messages that are beyond the provided FromTime
frontier will be relocked at times that will be beyond the returned IntoTime frontier.
This can be used to drive a IntoTime capability forward when the caller knows that a
FromTime frontier has advanced.
The method returns an error if the FromTime frontier is not beyond the since frontier.
The error will contain the offending FromTime.
sourcepub fn source_upper_at_frontier<'a>(
&self,
frontier: AntichainRef<'a, IntoTime>,
) -> Result<Antichain<FromTime>, ReclockError<AntichainRef<'a, IntoTime>>>
pub fn source_upper_at_frontier<'a>( &self, frontier: AntichainRef<'a, IntoTime>, ) -> Result<Antichain<FromTime>, ReclockError<AntichainRef<'a, IntoTime>>>
Reclocks an IntoTime frontier into a FromTime frontier.
The conversion has the property that all messages that would be reclocked to times beyond
the provided IntoTime frontier will be beyond the returned FromTime frontier. This can
be used to compute a safe starting point to resume producing an IntoTime collection at a
particular frontier.
sourcepub fn compact(&mut self, new_since: Antichain<IntoTime>)
pub fn compact(&mut self, new_since: Antichain<IntoTime>)
Compacts the trace held by this reclock follower to the specified frontier.
Reclocking has the property that it commutes with compaction. What this means is that reclocking a collection and then compacting the result to some frontier F will produce exactly the same result with first compacting the remap trace to frontier F and then reclocking the collection.
pub fn since(&self) -> AntichainRef<'_, IntoTime>
Trait Implementations§
Auto Trait Implementations§
impl<FromTime, IntoTime> Freeze for ReclockFollower<FromTime, IntoTime>where
IntoTime: Freeze,
impl<FromTime, IntoTime> !RefUnwindSafe for ReclockFollower<FromTime, IntoTime>
impl<FromTime, IntoTime> !Send for ReclockFollower<FromTime, IntoTime>
impl<FromTime, IntoTime> !Sync for ReclockFollower<FromTime, IntoTime>
impl<FromTime, IntoTime> Unpin for ReclockFollower<FromTime, IntoTime>where
IntoTime: Unpin,
impl<FromTime, IntoTime> !UnwindSafe for ReclockFollower<FromTime, IntoTime>
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> FmtForward for T
impl<T> FmtForward for T
source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.source§impl<T> FutureExt for T
impl<T> FutureExt for T
source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::Requestsource§impl<T, U> OverrideFrom<Option<&T>> for Uwhere
U: OverrideFrom<T>,
impl<T, U> OverrideFrom<Option<&T>> for Uwhere
U: OverrideFrom<T>,
source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moresource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moresource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.source§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<P, R> ProtoType<R> for Pwhere
R: RustType<P>,
impl<P, R> ProtoType<R> for Pwhere
R: RustType<P>,
source§fn into_rust(self) -> Result<R, TryFromProtoError>
fn into_rust(self) -> Result<R, TryFromProtoError>
RustType::from_proto.source§fn from_rust(rust: &R) -> P
fn from_rust(rust: &R) -> P
RustType::into_proto.source§impl<'a, S, T> Semigroup<&'a S> for Twhere
T: Semigroup<S>,
impl<'a, S, T> Semigroup<&'a S> for Twhere
T: Semigroup<S>,
source§fn plus_equals(&mut self, rhs: &&'a S)
fn plus_equals(&mut self, rhs: &&'a S)
std::ops::AddAssign, for types that do not implement AddAssign.source§impl<T> Tap for T
impl<T> Tap for T
source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moresource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moresource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moresource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moresource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moresource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moresource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.