pub struct PartitionedComputeState<T> {
parts: usize,
uppers: HashMap<GlobalId, MutableAntichain<T>>,
peek_responses: HashMap<Uuid, HashMap<usize, PeekResponse>>,
pending_tails: HashMap<GlobalId, Option<(MutableAntichain<T>, Vec<(T, Row, Diff)>)>>,
}
Expand description
Maintained state for partitioned compute clients.
This helper type unifies the responses of multiple partitioned workers in order to present as a single worker.
Fields
parts: usize
Number of partitions the state machine represents.
uppers: HashMap<GlobalId, MutableAntichain<T>>
Upper frontiers for indexes and sinks.
peek_responses: HashMap<Uuid, HashMap<usize, PeekResponse>>
Pending responses for a peek; returnable once all are available.
pending_tails: HashMap<GlobalId, Option<(MutableAntichain<T>, Vec<(T, Row, Diff)>)>>
Tracks in-progress TAIL
s, and the stashed rows we are holding
back until their timestamps are complete.
Implementations
sourceimpl<T> PartitionedComputeState<T> where
T: Timestamp + Copy,
impl<T> PartitionedComputeState<T> where
T: Timestamp + Copy,
fn reset(&mut self)
sourcepub fn observe_command(&mut self, command: &ComputeCommand<T>)
pub fn observe_command(&mut self, command: &ComputeCommand<T>)
Observes commands that move past, and prepares state for responses.
In particular, this method installs and removes upper frontier maintenance.
Trait Implementations
sourceimpl<T: Debug> Debug for PartitionedComputeState<T>
impl<T: Debug> Debug for PartitionedComputeState<T>
sourceimpl<T> PartitionedState<ComputeCommand<T>, ComputeResponse<T>> for PartitionedComputeState<T> where
T: Timestamp + Copy,
impl<T> PartitionedState<ComputeCommand<T>, ComputeResponse<T>> for PartitionedComputeState<T> where
T: Timestamp + Copy,
sourcefn split_command(
&mut self,
command: ComputeCommand<T>
) -> Vec<ComputeCommand<T>>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
fn split_command(
&mut self,
command: ComputeCommand<T>
) -> Vec<ComputeCommand<T>>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
A: Allocator,
Splits a command into multiple partitions.
sourcefn absorb_response(
&mut self,
shard_id: usize,
message: ComputeResponse<T>
) -> Option<Result<ComputeResponse<T>, Error>>
fn absorb_response(
&mut self,
shard_id: usize,
message: ComputeResponse<T>
) -> Option<Result<ComputeResponse<T>, Error>>
Absorbs a response from a single partition. Read more
Auto Trait Implementations
impl<T> RefUnwindSafe for PartitionedComputeState<T> where
T: RefUnwindSafe,
impl<T> Send for PartitionedComputeState<T> where
T: Send,
impl<T> Sync for PartitionedComputeState<T> where
T: Sync,
impl<T> Unpin for PartitionedComputeState<T> where
T: Unpin,
impl<T> UnwindSafe for PartitionedComputeState<T> where
T: UnwindSafe,
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