pub struct StreamFwder { /* private fields */ }Expand description
Given a stream forwards data to the provided channel.
Implementations§
Source§impl StreamFwder
impl StreamFwder
Sourcepub fn start(
reader: impl AsyncRead + Unpin + Send + 'static,
file_monitor_addr: Option<ChannelAddr>,
target: OutputTarget,
max_buffer_size: usize,
log_channel: Option<ChannelAddr>,
proc_id: &ProcAddr,
local_rank: usize,
) -> Self
pub fn start( reader: impl AsyncRead + Unpin + Send + 'static, file_monitor_addr: Option<ChannelAddr>, target: OutputTarget, max_buffer_size: usize, log_channel: Option<ChannelAddr>, proc_id: &ProcAddr, local_rank: usize, ) -> Self
Create a new StreamFwder instance, and start monitoring the provided path. Once started Monitor will
- forward logs to log_sender
- forward logs to file_monitor (if available)
- pipe reader to target
- And capture last
max_buffer_sizewhich can be used to inspect file contents viapeek.
pub async fn abort(self) -> (Vec<String>, Result<(), Error>)
Auto Trait Implementations§
impl Freeze for StreamFwder
impl !RefUnwindSafe for StreamFwder
impl Send for StreamFwder
impl Sync for StreamFwder
impl Unpin for StreamFwder
impl UnsafeUnpin for StreamFwder
impl !UnwindSafe for StreamFwder
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
Source§impl<A, M> Handler<IndexedErasedUnbound<M>> for A
impl<A, M> Handler<IndexedErasedUnbound<M>> for A
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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 more§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].