From 1cf04aa0a3fb2378ad11dee260b80dcd4de8dd26 Mon Sep 17 00:00:00 2001 From: Paul Masurel Date: Wed, 8 May 2024 13:27:46 +0900 Subject: [PATCH] Re-added acquire_with_duration in rate_limiter. (#4952) --- quickwit/quickwit-common/src/rate_limiter.rs | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/quickwit/quickwit-common/src/rate_limiter.rs b/quickwit/quickwit-common/src/rate_limiter.rs index 0b80a7e17db..0e748d65913 100644 --- a/quickwit/quickwit-common/src/rate_limiter.rs +++ b/quickwit/quickwit-common/src/rate_limiter.rs @@ -101,6 +101,23 @@ impl RateLimiter { } } + /// Acquires some permits from the rate limiter. + /// If the permits are not available, returns the duration to wait before trying again. + /// + /// This method is currently only used in simian. + pub fn acquire_with_duration(&mut self, num_permits: u64) -> Result<(), Duration> { + if self.acquire_inner(num_permits) { + return Ok(()); + } + self.refill(Instant::now()); + if self.acquire_inner(num_permits) { + return Ok(()); + } + let missing = num_permits - self.available_permits; + let wait = Duration::from_micros(missing * self.refill_period_micros / self.refill_amount); + Err(wait) + } + /// Acquires some permits expressed in bytes from the rate limiter. Returns whether the permits /// were acquired. pub fn acquire_bytes(&mut self, bytes: ByteSize) -> bool {