pub struct PprofAlloc<A = System> { /* private fields */ }Expand description
Global allocator wrapper that can collect allocation counters and pprof heap profiles.
Use this as a #[global_allocator] around std::alloc::System or another
allocator implementing GlobalAlloc. Profiling and coarse allocation
counters are opt-in through the builder methods.
Implementations§
Source§impl PprofAlloc<System>
impl PprofAlloc<System>
Sourcepub const fn new() -> Self
pub const fn new() -> Self
Create a wrapper around std::alloc::System with profiling disabled.
Use Self::with_pprof, Self::with_pprof_sample_rate, or
Self::with_stats to enable collection.
Source§impl<A> PprofAlloc<A>
impl<A> PprofAlloc<A>
Sourcepub const fn from_allocator(inner: A) -> Self
pub const fn from_allocator(inner: A) -> Self
Create a wrapper around a custom allocator with profiling disabled.
Sourcepub const fn with_pprof(self) -> Self
pub const fn with_pprof(self) -> Self
Enable sampled pprof stack profiling using DEFAULT_PPROF_SAMPLE_RATE.
Sourcepub const fn with_pprof_sample_rate(self, bytes: usize) -> Self
pub const fn with_pprof_sample_rate(self, bytes: usize) -> Self
Enable sampled pprof stack profiling with an explicit byte sample rate.
A rate of 1 records every allocation. A rate of 0 disables pprof
stack recording while still allowing other enabled collectors to run.
Sourcepub const fn with_pprof_sample_rate_from_env(self, default_rate: usize) -> Self
pub const fn with_pprof_sample_rate_from_env(self, default_rate: usize) -> Self
Enable pprof stack profiling with the sample rate read from the environment.
PPROF_SAMPLE_RATE_ENV is read lazily on the first profiled allocation.
If the variable is missing or invalid, default_rate is used.
Sourcepub const fn with_stats(self) -> Self
pub const fn with_stats(self) -> Self
Enable coarse process-wide allocation and free counters.
Trait Implementations§
Source§impl Default for PprofAlloc<System>
impl Default for PprofAlloc<System>
Source§impl<A: GlobalAlloc> GlobalAlloc for PprofAlloc<A>
impl<A: GlobalAlloc> GlobalAlloc for PprofAlloc<A>
Source§unsafe fn alloc(&self, layout: Layout) -> *mut u8
unsafe fn alloc(&self, layout: Layout) -> *mut u8
layout. Read moreSource§unsafe fn alloc_zeroed(&self, layout: Layout) -> *mut u8
unsafe fn alloc_zeroed(&self, layout: Layout) -> *mut u8
alloc, but also ensures that the contents
are set to zero before being returned. Read moreAuto Trait Implementations§
impl<A> Freeze for PprofAlloc<A>where
A: Freeze,
impl<A> RefUnwindSafe for PprofAlloc<A>where
A: RefUnwindSafe,
impl<A> Send for PprofAlloc<A>where
A: Send,
impl<A> Sync for PprofAlloc<A>where
A: Sync,
impl<A> Unpin for PprofAlloc<A>where
A: Unpin,
impl<A> UnsafeUnpin for PprofAlloc<A>where
A: UnsafeUnpin,
impl<A> UnwindSafe for PprofAlloc<A>where
A: UnwindSafe,
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
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>
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>
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