Skip to main content

SamplingMiddleware

Struct SamplingMiddleware 

Source
pub struct SamplingMiddleware { /* private fields */ }
Expand description

Sampling middleware for statistical message sampling.

Allows only a percentage of messages to pass through, useful for monitoring, testing, or load reduction.

§Examples

use celers_kombu::SamplingMiddleware;

// Sample 10% of messages
let sampler = SamplingMiddleware::new(0.1);
assert_eq!(sampler.sample_rate(), 0.1);

Implementations§

Source§

impl SamplingMiddleware

Source

pub fn new(sample_rate: f64) -> Self

Create a new sampling middleware with the given sample rate.

Sample rate should be between 0.0 and 1.0, where:

  • 0.0 = sample nothing
  • 1.0 = sample everything
  • 0.1 = sample approximately 10% of messages
Source

pub fn sample_rate(&self) -> f64

Get the configured sample rate

Trait Implementations§

Source§

impl MessageMiddleware for SamplingMiddleware

Source§

fn before_publish<'life0, 'life1, 'async_trait>( &'life0 self, _message: &'life1 mut Message, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Process message before publishing
Source§

fn after_consume<'life0, 'life1, 'async_trait>( &'life0 self, _message: &'life1 mut Message, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Process message after consuming
Source§

fn name(&self) -> &str

Get middleware name for logging

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.