struct TrackFull {
seen_positions: HashMap<RowCoordinates, i64>,
seen_snapshot_keys: HashSet<Row>,
max_seen_time: i64,
range: Option<TrackRange>,
started_padding: bool,
started: bool,
}
Expand description
If we need to deal with debezium possibly going back after it hasn’t seen things. During normal (non-snapshot) operation, we deduplicate based on binlog position: (pos, row), for MySQL. During the initial snapshot, (pos, row) values are all the same, but primary keys are unique and thus we can get deduplicate based on those.
Fields
seen_positions: HashMap<RowCoordinates, i64>
binlog position to (timestamp that this binlog entry was first seen)
seen_snapshot_keys: HashSet<Row>
max_seen_time: i64
The highest-ever seen timestamp, used in logging to let us know how far backwards time might go
range: Option<TrackRange>
started_padding: bool
started: bool
Whether we have started full deduplication mode
Implementations
sourceimpl TrackFull
impl TrackFull
fn from_keys() -> Self
fn from_keys_in_range(
start: NaiveDateTime,
end: NaiveDateTime,
pad_start: Option<NaiveDateTime>
) -> Self
Trait Implementations
Auto Trait Implementations
impl RefUnwindSafe for TrackFull
impl Send for TrackFull
impl Sync for TrackFull
impl Unpin for TrackFull
impl UnwindSafe for TrackFull
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> FutureExt for T
impl<T> FutureExt for T
sourcefn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
sourcefn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
sourcefn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message T
in a tonic::Request
sourceimpl<P, R> ProtoType<R> for P where
R: RustType<P>,
impl<P, R> ProtoType<R> for P where
R: RustType<P>,
sourcefn into_rust(self) -> Result<R, TryFromProtoError>
fn into_rust(self) -> Result<R, TryFromProtoError>
See RustType::from_proto
.
sourcefn from_rust(rust: &R) -> P
fn from_rust(rust: &R) -> P
See RustType::into_proto
.
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
Attaches the provided Subscriber
to this type, returning a
WithDispatch
wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more