Tune timings of dynamic threadpool

tosocketaddrs
Tyler Neely 5 years ago
parent e97dfdc4cc
commit d75aae23cb

@ -14,9 +14,9 @@ use lazy_static::lazy_static;
use crate::utils::abort_on_panic; use crate::utils::abort_on_panic;
const MAX_THREADS: u64 = 10_000; const MAX_THREADS: u64 = 10_000;
const MIN_WAIT_MS: u64 = 1; const MIN_WAIT_US: u64 = 10;
const MAX_WAIT_MS: u64 = 100; const MAX_WAIT_US: u64 = 10_000;
const WAIT_SPREAD: u64 = MAX_WAIT_MS - MIN_WAIT_MS; const WAIT_SPREAD: u64 = MAX_WAIT_US - MIN_WAIT_US;
static DYNAMIC_THREAD_COUNT: AtomicU64 = AtomicU64::new(0); static DYNAMIC_THREAD_COUNT: AtomicU64 = AtomicU64::new(0);
@ -64,9 +64,9 @@ fn maybe_create_another_blocking_thread() {
let relative_wait_limit = (WAIT_SPREAD * utilization_percent) / 100; let relative_wait_limit = (WAIT_SPREAD * utilization_percent) / 100;
// higher utilization -> lower wait time // higher utilization -> lower wait time
let wait_limit_ms = MAX_WAIT_MS - relative_wait_limit; let wait_limit_us = MAX_WAIT_US - relative_wait_limit;
assert!(wait_limit_ms >= MIN_WAIT_MS); assert!(wait_limit_us >= MIN_WAIT_US);
let wait_limit = Duration::from_millis(wait_limit_ms); let wait_limit = Duration::from_micros(wait_limit_us);
thread::Builder::new() thread::Builder::new()
.name("async-blocking-driver-dynamic".to_string()) .name("async-blocking-driver-dynamic".to_string())
@ -96,9 +96,9 @@ fn schedule(t: async_task::Task<()>) {
let relative_wait_limit = (WAIT_SPREAD * utilization_percent) / 100; let relative_wait_limit = (WAIT_SPREAD * utilization_percent) / 100;
// higher utilization -> higher block time // higher utilization -> higher block time
let wait_limit_ms = MIN_WAIT_MS + relative_wait_limit; let wait_limit_us = MIN_WAIT_US + relative_wait_limit;
assert!(wait_limit_ms <= MAX_WAIT_MS); assert!(wait_limit_us <= MAX_WAIT_US);
let wait_limit = Duration::from_millis(wait_limit_ms); let wait_limit = Duration::from_micros(wait_limit_us);
let first_try_result = POOL.sender.send_timeout(t, wait_limit); let first_try_result = POOL.sender.send_timeout(t, wait_limit);
match first_try_result { match first_try_result {

Loading…
Cancel
Save