pub struct StreamSupervisor { /* private fields */ }Expand description
Supervises stream workers and restarts them on failure.
Tracks worker health, enforces restart limits, and optionally propagates failures to sibling workers (one-for-all supervision strategy).
Implementations§
Source§impl StreamSupervisor
impl StreamSupervisor
Sourcepub fn new(config: SupervisorConfig) -> Self
pub fn new(config: SupervisorConfig) -> Self
Creates a new supervisor with the given configuration.
Sourcepub fn register_worker(&self, worker_id: impl Into<String>)
pub fn register_worker(&self, worker_id: impl Into<String>)
Registers a worker with the supervisor.
Sourcepub fn report_failure(
&self,
worker_id: &str,
reason: &str,
) -> FaultResult<WorkerStatus>
pub fn report_failure( &self, worker_id: &str, reason: &str, ) -> FaultResult<WorkerStatus>
Notifies the supervisor that a worker has failed.
The supervisor will attempt to restart the worker unless the restart limit has been reached.
Returns the new worker status.
Sourcepub fn acknowledge_restart(&self, worker_id: &str) -> FaultResult<()>
pub fn acknowledge_restart(&self, worker_id: &str) -> FaultResult<()>
Acknowledges that a worker has successfully restarted.
Sourcepub fn stop_worker(&self, worker_id: &str) -> FaultResult<()>
pub fn stop_worker(&self, worker_id: &str) -> FaultResult<()>
Stops a worker intentionally.
Sourcepub fn worker_status(&self, worker_id: &str) -> Option<WorkerStatus>
pub fn worker_status(&self, worker_id: &str) -> Option<WorkerStatus>
Returns the current status of a worker.
Sourcepub fn workers_with_status(&self, status: &WorkerStatus) -> Vec<String>
pub fn workers_with_status(&self, status: &WorkerStatus) -> Vec<String>
Returns all workers whose status matches the given status.
Sourcepub fn stats(&self) -> SupervisorStats
pub fn stats(&self) -> SupervisorStats
Returns supervisor statistics.
Sourcepub fn restart_history(&self) -> Vec<RestartRecord>
pub fn restart_history(&self) -> Vec<RestartRecord>
Returns the full restart history.
Auto Trait Implementations§
impl Freeze for StreamSupervisor
impl !RefUnwindSafe for StreamSupervisor
impl Send for StreamSupervisor
impl Sync for StreamSupervisor
impl Unpin for StreamSupervisor
impl UnsafeUnpin for StreamSupervisor
impl !UnwindSafe for StreamSupervisor
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
Mutably borrows from an owned value. Read more
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> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.