Struct mz_compute_client::controller::replicated::ActiveReplication
source · [−]pub(super) struct ActiveReplication<T> {
build_info: &'static BuildInfo,
replicas: HashMap<ReplicaId, ReplicaState<T>>,
state: ActiveReplicationState<T>,
}
Expand description
A client backed by multiple replicas.
Fields
build_info: &'static BuildInfo
The build information for this process.
replicas: HashMap<ReplicaId, ReplicaState<T>>
State for each replica.
state: ActiveReplicationState<T>
All other internal state of the client
Implementations
sourceimpl<T> ActiveReplication<T>
impl<T> ActiveReplication<T>
sourceimpl<T> ActiveReplication<T>where
T: Timestamp + Lattice,
ComputeGrpcClient: ComputeClient<T>,
impl<T> ActiveReplication<T>where
T: Timestamp + Lattice,
ComputeGrpcClient: ComputeClient<T>,
sourcepub(super) fn add_replica(
&mut self,
id: ReplicaId,
addrs: Vec<String>,
logging_config: Option<LoggingConfig>,
communication_config: CommunicationConfig
)
pub(super) fn add_replica(
&mut self,
id: ReplicaId,
addrs: Vec<String>,
logging_config: Option<LoggingConfig>,
communication_config: CommunicationConfig
)
Introduce a new replica, and catch it up to the commands of other replicas.
It is not yet clear under which circumstances a replica can be removed.
sourcepub(super) fn get_replica_ids(&self) -> impl Iterator<Item = ReplicaId> + '_
pub(super) fn get_replica_ids(&self) -> impl Iterator<Item = ReplicaId> + '_
Returns an iterator over the IDs of the replicas.
sourcepub(super) fn remove_replica(&mut self, id: ReplicaId)
pub(super) fn remove_replica(&mut self, id: ReplicaId)
Remove a replica by its identifier.
fn rehydrate_replica(&mut self, id: ReplicaId)
sourcepub(super) fn send(&mut self, cmd: ComputeCommand<T>)
pub(super) fn send(&mut self, cmd: ComputeCommand<T>)
Sends a command to all replicas.
sourcepub(super) async fn recv(&mut self) -> ActiveReplicationResponse<T>
pub(super) async fn recv(&mut self) -> ActiveReplicationResponse<T>
Receives the next response from any replica.
This method is cancellation safe.
Trait Implementations
Auto Trait Implementations
impl<T> !RefUnwindSafe for ActiveReplication<T>
impl<T> Send for ActiveReplication<T>where
T: Send,
impl<T> Sync for ActiveReplication<T>where
T: Send + Sync,
impl<T> Unpin for ActiveReplication<T>where
T: Unpin,
impl<T> !UnwindSafe for ActiveReplication<T>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
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<T> Pointable for T
impl<T> Pointable for T
sourceimpl<P, R> ProtoType<R> for Pwhere
R: RustType<P>,
impl<P, R> ProtoType<R> for Pwhere
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
.