add more program options for tokio
Signed-off-by: Jason Volk <jason@zemos.net>
This commit is contained in:
parent
503210c3bf
commit
aefc4b4e69
2 changed files with 23 additions and 7 deletions
|
@ -36,9 +36,26 @@ pub(crate) struct Args {
|
|||
pub(crate) test: Vec<String>,
|
||||
|
||||
/// Override the tokio worker_thread count.
|
||||
#[arg(long, hide(true), env = "TOKIO_WORKER_THREADS", default_value = available_parallelism().to_string())]
|
||||
#[arg(
|
||||
long,
|
||||
hide(true),
|
||||
env = "TOKIO_WORKER_THREADS",
|
||||
default_value = available_parallelism().to_string(),
|
||||
)]
|
||||
pub(crate) worker_threads: usize,
|
||||
|
||||
/// Override the tokio global_queue_interval.
|
||||
#[arg(long, hide(true), env = "TOKIO_GLOBAL_QUEUE_INTERVAL", default_value = "192")]
|
||||
pub(crate) global_event_interval: u32,
|
||||
|
||||
/// Override the tokio event_interval.
|
||||
#[arg(long, hide(true), env = "TOKIO_EVENT_INTERVAL", default_value = "512")]
|
||||
pub(crate) kernel_event_interval: u32,
|
||||
|
||||
/// Override the tokio max_io_events_per_tick.
|
||||
#[arg(long, hide(true), env = "TOKIO_MAX_IO_EVENTS_PER_TICK", default_value = "512")]
|
||||
pub(crate) kernel_events_per_tick: usize,
|
||||
|
||||
/// Set the histogram bucket size, in microseconds (tokio_unstable). Default
|
||||
/// is 25 microseconds. If the values of the histogram don't approach zero
|
||||
/// with the exception of the last bucket, try increasing this value to e.g.
|
||||
|
|
|
@ -8,9 +8,7 @@ use crate::clap::Args;
|
|||
const WORKER_NAME: &str = "conduwuit:worker";
|
||||
const WORKER_MIN: usize = 2;
|
||||
const WORKER_KEEPALIVE: u64 = 36;
|
||||
const GLOBAL_QUEUE_INTERVAL: u32 = 192;
|
||||
const KERNEL_QUEUE_INTERVAL: u32 = 256;
|
||||
const KERNEL_EVENTS_PER_TICK: usize = 512;
|
||||
const MAX_BLOCKING_THREADS: usize = 1024;
|
||||
|
||||
static WORKER_AFFINITY: OnceLock<bool> = OnceLock::new();
|
||||
|
||||
|
@ -25,10 +23,11 @@ pub(super) fn new(args: &Args) -> Result<tokio::runtime::Runtime> {
|
|||
.enable_time()
|
||||
.thread_name(WORKER_NAME)
|
||||
.worker_threads(args.worker_threads.max(WORKER_MIN))
|
||||
.max_blocking_threads(MAX_BLOCKING_THREADS)
|
||||
.thread_keep_alive(Duration::from_secs(WORKER_KEEPALIVE))
|
||||
.max_io_events_per_tick(KERNEL_EVENTS_PER_TICK)
|
||||
.event_interval(KERNEL_QUEUE_INTERVAL)
|
||||
.global_queue_interval(GLOBAL_QUEUE_INTERVAL)
|
||||
.global_queue_interval(args.global_event_interval)
|
||||
.event_interval(args.kernel_event_interval)
|
||||
.max_io_events_per_tick(args.kernel_events_per_tick)
|
||||
.on_thread_start(thread_start)
|
||||
.on_thread_stop(thread_stop)
|
||||
.on_thread_unpark(thread_unpark)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue