linera_core/client/requests_scheduler/
mod.rs1mod cache;
8mod in_flight_tracker;
9mod node_info;
10mod request;
11mod scheduler;
12mod scoring;
13
14pub use scheduler::RequestsScheduler;
15pub use scoring::ScoringWeights;
16
17pub const MAX_IN_FLIGHT_REQUESTS: usize = 100;
19pub const MAX_ACCEPTED_LATENCY_MS: f64 = 5000.0;
20pub const CACHE_TTL_MS: u64 = 2000;
21pub const CACHE_MAX_SIZE: usize = 1000;
22pub const MAX_REQUEST_TTL_MS: u64 = 200;
23pub const ALPHA_SMOOTHING_FACTOR: f64 = 0.1;
24
25#[derive(Debug, Clone)]
27pub struct RequestsSchedulerConfig {
28 pub max_accepted_latency_ms: f64,
30 pub cache_ttl_ms: u64,
32 pub cache_max_size: usize,
34 pub max_request_ttl_ms: u64,
36 pub alpha: f64,
38}
39
40impl Default for RequestsSchedulerConfig {
41 fn default() -> Self {
42 Self {
43 max_accepted_latency_ms: MAX_ACCEPTED_LATENCY_MS,
44 cache_ttl_ms: CACHE_TTL_MS,
45 cache_max_size: CACHE_MAX_SIZE,
46 max_request_ttl_ms: MAX_REQUEST_TTL_MS,
47 alpha: ALPHA_SMOOTHING_FACTOR,
48 }
49 }
50}