Struct mz_ore::metrics::ExecTimeFuture
source · pub struct ExecTimeFuture<F, Metric> {
fut: F,
metric: Metric,
running_duration: Duration,
filter: Option<Box<dyn FnMut(Duration) -> bool + Send + Sync>>,
}
Available on crate feature
metrics
only.Expand description
Future returned by MetricsFutureExt::exec_time
.
Fields§
§fut: F
The inner Future
that we’re recording the wall time for.
metric: Metric
Prometheus metric that we’ll report to.
running_duration: Duration
§filter: Option<Box<dyn FnMut(Duration) -> bool + Send + Sync>>
Optional filter that determines if we observe the execution time of this Future
.
Implementations§
source§impl<F, Metric> ExecTimeFuture<F, Metric>
impl<F, Metric> ExecTimeFuture<F, Metric>
pub(crate) fn project<'pin>( self: Pin<&'pin mut Self>, ) -> __ExecTimeFutureProjection<'pin, F, Metric>
pub(crate) fn project_ref<'pin>( self: Pin<&'pin Self>, ) -> __ExecTimeFutureProjectionRef<'pin, F, Metric>
source§impl<F> ExecTimeFuture<F, UnspecifiedMetric>
impl<F> ExecTimeFuture<F, UnspecifiedMetric>
sourcepub fn observe(self, histogram: Histogram) -> ExecTimeFuture<F, Histogram> ⓘ
pub fn observe(self, histogram: Histogram) -> ExecTimeFuture<F, Histogram> ⓘ
Sets the recored metric to be a prometheus::Histogram
.
my_future
.exec_time()
.observe(metrics.slow_queries_hist.with_label_values(&["select"]))
sourcepub fn inc_by(self, counter: Counter) -> ExecTimeFuture<F, Counter> ⓘ
pub fn inc_by(self, counter: Counter) -> ExecTimeFuture<F, Counter> ⓘ
Sets the recored metric to be a prometheus::Counter
.
my_future
.exec_time()
.inc_by(metrics.slow_queries.with_label_values(&["select"]))
source§impl<F, M> ExecTimeFuture<F, M>
impl<F, M> ExecTimeFuture<F, M>
Trait Implementations§
source§impl<F: Future, M: DurationMetric> Future for ExecTimeFuture<F, M>
impl<F: Future, M: DurationMetric> Future for ExecTimeFuture<F, M>
impl<'pin, F, Metric> Unpin for ExecTimeFuture<F, Metric>where
__ExecTimeFuture<'pin, F, Metric>: Unpin,
Auto Trait Implementations§
impl<F, Metric> Freeze for ExecTimeFuture<F, Metric>
impl<F, Metric> !RefUnwindSafe for ExecTimeFuture<F, Metric>
impl<F, Metric> Send for ExecTimeFuture<F, Metric>
impl<F, Metric> Sync for ExecTimeFuture<F, Metric>
impl<F, Metric> !UnwindSafe for ExecTimeFuture<F, Metric>
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> FutureExt for T
impl<T> FutureExt for T
source§fn map<U, F>(self, f: F) -> Map<Self, F>
fn map<U, F>(self, f: F) -> Map<Self, F>
Map this future’s output to a different type, returning a new future of
the resulting type. Read more
source§fn map_into<U>(self) -> MapInto<Self, U>
fn map_into<U>(self) -> MapInto<Self, U>
Map this future’s output to a different type, returning a new future of
the resulting type. Read more
source§fn then<Fut, F>(self, f: F) -> Then<Self, Fut, F>
fn then<Fut, F>(self, f: F) -> Then<Self, Fut, F>
Chain on a computation for when a future finished, passing the result of
the future to the provided closure
f
. Read moresource§fn left_future<B>(self) -> Either<Self, B>
fn left_future<B>(self) -> Either<Self, B>
source§fn right_future<A>(self) -> Either<A, Self>
fn right_future<A>(self) -> Either<A, Self>
source§fn into_stream(self) -> IntoStream<Self>where
Self: Sized,
fn into_stream(self) -> IntoStream<Self>where
Self: Sized,
Convert this future into a single element stream. Read more
source§fn flatten(self) -> Flatten<Self>
fn flatten(self) -> Flatten<Self>
Flatten the execution of this future when the output of this
future is itself another future. Read more
source§fn flatten_stream(self) -> FlattenStream<Self>
fn flatten_stream(self) -> FlattenStream<Self>
Flatten the execution of this future when the successful result of this
future is a stream. Read more
source§fn fuse(self) -> Fuse<Self>where
Self: Sized,
fn fuse(self) -> Fuse<Self>where
Self: Sized,
Fuse a future such that
poll
will never again be called once it has
completed. This method can be used to turn any Future
into a
FusedFuture
. Read moresource§fn inspect<F>(self, f: F) -> Inspect<Self, F>
fn inspect<F>(self, f: F) -> Inspect<Self, F>
Do something with the output of a future before passing it on. Read more
source§fn catch_unwind(self) -> CatchUnwind<Self>where
Self: Sized + UnwindSafe,
fn catch_unwind(self) -> CatchUnwind<Self>where
Self: Sized + UnwindSafe,
Catches unwinding panics while polling the future. Read more
Create a cloneable handle to this future where all handles will resolve
to the same result. Read more
source§fn remote_handle(self) -> (Remote<Self>, RemoteHandle<Self::Output>)where
Self: Sized,
fn remote_handle(self) -> (Remote<Self>, RemoteHandle<Self::Output>)where
Self: Sized,
Turn this future into a future that yields
()
on completion and sends
its output to another future on a separate task. Read moresource§fn boxed<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + Send + 'a>>
fn boxed<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + Send + 'a>>
Wrap the future in a Box, pinning it. Read more
source§fn boxed_local<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + 'a>>where
Self: Sized + 'a,
fn boxed_local<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + 'a>>where
Self: Sized + 'a,
Wrap the future in a Box, pinning it. Read more
source§fn unit_error(self) -> UnitError<Self>where
Self: Sized,
fn unit_error(self) -> UnitError<Self>where
Self: Sized,
Turns a
Future<Output = T>
into a
TryFuture<Ok = T, Error = ()
>.source§fn never_error(self) -> NeverError<Self>where
Self: Sized,
fn never_error(self) -> NeverError<Self>where
Self: Sized,
Turns a
Future<Output = T>
into a
TryFuture<Ok = T, Error = Never
>.source§impl<T> FutureExt for T
impl<T> FutureExt for T
source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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<F> IntoFuture for Fwhere
F: Future,
impl<F> IntoFuture for Fwhere
F: Future,
§type IntoFuture = F
type IntoFuture = F
Which kind of future are we turning this into?
source§fn into_future(self) -> <F as IntoFuture>::IntoFuture
fn into_future(self) -> <F as IntoFuture>::IntoFuture
Creates a future from a value. Read more
source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request
source§impl<F> MetricsFutureExt<F> for Fwhere
F: Future,
impl<F> MetricsFutureExt<F> for Fwhere
F: Future,
source§fn wall_time(self) -> WallTimeFuture<F, UnspecifiedMetric> ⓘ
fn wall_time(self) -> WallTimeFuture<F, UnspecifiedMetric> ⓘ
Available on crate feature
metrics
only.source§fn exec_time(self) -> ExecTimeFuture<F, UnspecifiedMetric> ⓘ
fn exec_time(self) -> ExecTimeFuture<F, UnspecifiedMetric> ⓘ
Available on crate feature
metrics
only.source§impl<T> OreFutureExt for Twhere
T: Future,
impl<T> OreFutureExt for Twhere
T: Future,
source§fn spawn_if_canceled<Name, NameClosure>(
self,
nc: NameClosure,
) -> SpawnIfCanceled<<T as Future>::Output, Name, NameClosure> ⓘ
fn spawn_if_canceled<Name, NameClosure>( self, nc: NameClosure, ) -> SpawnIfCanceled<<T as Future>::Output, Name, NameClosure> ⓘ
Available on crate feature
async
only.Wraps a future in a
SpawnIfCanceled
future, which will spawn a
task to poll the inner future to completion if it is dropped.source§fn run_in_task<'async_trait, Name, NameClosure>(
self,
nc: NameClosure,
) -> Pin<Box<dyn Future<Output = <T as Future>::Output> + Send + 'async_trait>>
fn run_in_task<'async_trait, Name, NameClosure>( self, nc: NameClosure, ) -> Pin<Box<dyn Future<Output = <T as Future>::Output> + Send + 'async_trait>>
Available on crate feature
async
only.Run a
'static
future in a Tokio task, naming that task, using a convenient
postfix call notation. Read moresource§fn run_in_task_if<'async_trait, Name, NameClosure>(
self,
in_task: InTask,
nc: NameClosure,
) -> Pin<Box<dyn Future<Output = <T as Future>::Output> + Send + 'async_trait>>
fn run_in_task_if<'async_trait, Name, NameClosure>( self, in_task: InTask, nc: NameClosure, ) -> Pin<Box<dyn Future<Output = <T as Future>::Output> + Send + 'async_trait>>
Available on crate feature
async
only.The same as
run_in_task
, but allows the callee to dynamically choose whether or
not the future is polled into a Tokio task.source§fn ore_catch_unwind(self) -> OreCatchUnwind<T> ⓘwhere
T: UnwindSafe,
fn ore_catch_unwind(self) -> OreCatchUnwind<T> ⓘwhere
T: UnwindSafe,
Available on crate feature
async
only.Like
FutureExt::catch_unwind
, but can unwind panics even if
panic::install_enhanced_handler
has been called.source§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<F> SentryFutureExt for Fwhere
F: Future,
impl<F> SentryFutureExt for Fwhere
F: Future,
source§impl<Fut> TryFutureExt for Fut
impl<Fut> TryFutureExt for Fut
source§fn flatten_sink<Item>(self) -> FlattenSink<Self, Self::Ok>
fn flatten_sink<Item>(self) -> FlattenSink<Self, Self::Ok>
source§fn map_ok<T, F>(self, f: F) -> MapOk<Self, F>
fn map_ok<T, F>(self, f: F) -> MapOk<Self, F>
Maps this future’s success value to a different value. Read more
source§fn map_ok_or_else<T, E, F>(self, e: E, f: F) -> MapOkOrElse<Self, F, E>
fn map_ok_or_else<T, E, F>(self, e: E, f: F) -> MapOkOrElse<Self, F, E>
Maps this future’s success value to a different value, and permits for error handling resulting in the same type. Read more
source§fn map_err<E, F>(self, f: F) -> MapErr<Self, F>
fn map_err<E, F>(self, f: F) -> MapErr<Self, F>
Maps this future’s error value to a different value. Read more
source§fn and_then<Fut, F>(self, f: F) -> AndThen<Self, Fut, F>
fn and_then<Fut, F>(self, f: F) -> AndThen<Self, Fut, F>
Executes another future after this one resolves successfully. The
success value is passed to a closure to create this subsequent future. Read more
source§fn or_else<Fut, F>(self, f: F) -> OrElse<Self, Fut, F>
fn or_else<Fut, F>(self, f: F) -> OrElse<Self, Fut, F>
Executes another future if this one resolves to an error. The
error value is passed to a closure to create this subsequent future. Read more
source§fn inspect_ok<F>(self, f: F) -> InspectOk<Self, F>
fn inspect_ok<F>(self, f: F) -> InspectOk<Self, F>
Do something with the success value of a future before passing it on. Read more
source§fn inspect_err<F>(self, f: F) -> InspectErr<Self, F>
fn inspect_err<F>(self, f: F) -> InspectErr<Self, F>
Do something with the error value of a future before passing it on. Read more
source§fn try_flatten(self) -> TryFlatten<Self, Self::Ok>
fn try_flatten(self) -> TryFlatten<Self, Self::Ok>
Flatten the execution of this future when the successful result of this
future is another future. Read more
source§fn try_flatten_stream(self) -> TryFlattenStream<Self>
fn try_flatten_stream(self) -> TryFlattenStream<Self>
Flatten the execution of this future when the successful result of this
future is a stream. Read more