Skip to content

Commit

Permalink
Making ingest timeout configurable.
Browse files Browse the repository at this point in the history
  • Loading branch information
fulmicoton committed May 13, 2024
1 parent 770d8a7 commit 11165f8
Showing 1 changed file with 19 additions and 9 deletions.
28 changes: 19 additions & 9 deletions quickwit/quickwit-ingest/src/ingest_v2/router.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@

use std::collections::{HashMap, HashSet};
use std::fmt;
use std::sync::{Arc, Weak};
use std::sync::{Arc, OnceLock, Weak};
use std::time::Duration;

use async_trait::async_trait;
Expand Down Expand Up @@ -53,11 +53,21 @@ use super::IngesterPool;
use crate::{get_ingest_router_buffer_size, LeaderId};

/// Duration after which ingest requests time out with [`IngestV2Error::Timeout`].
pub(super) const INGEST_REQUEST_TIMEOUT: Duration = if cfg!(any(test, feature = "testsuite")) {
Duration::from_millis(10)
} else {
Duration::from_secs(35)
};
fn ingest_request_timeout() -> Duration {
const DEFAULT_INGEST_REQUEST_TIMEOUT: Duration = if cfg!(any(test, feature = "testsuite")) {
Duration::from_millis(10)
} else {
Duration::from_secs(35)
};
static TIMEOUT: OnceLock<Duration> = OnceLock::new();
*TIMEOUT.get_or_init(|| {
let duration_ms = quickwit_common::get_from_env(
"QW_INGEST_REQUEST_TIMEOUT_MS",
DEFAULT_INGEST_REQUEST_TIMEOUT.as_millis() as u64,
);
Duration::from_millis(duration_ms)
})
}

const MAX_PERSIST_ATTEMPTS: usize = 5;

Expand Down Expand Up @@ -435,8 +445,8 @@ impl IngestRouter {
.await
.map_err(|_| {
let message = format!(
"ingest request timed out after {} seconds",
INGEST_REQUEST_TIMEOUT.as_secs()
"ingest request timed out after {} millis",
timeout_duration.as_millis()
);
IngestV2Error::Timeout(message)
})?
Expand All @@ -460,7 +470,7 @@ impl IngestRouterService for IngestRouter {
.try_acquire_many_owned(request_size_bytes as u32)
.map_err(|_| IngestV2Error::TooManyRequests)?;

self.ingest_timeout(ingest_request, INGEST_REQUEST_TIMEOUT)
self.ingest_timeout(ingest_request, ingest_request_timeout())
.await
}
}
Expand Down

0 comments on commit 11165f8

Please sign in to comment.