mirror of
https://github.com/DNSCrypt/doh-server.git
synced 2025-04-03 04:57:37 +03:00
Limit the number of concurrent streams per client
This commit is contained in:
parent
a2f342379e
commit
b4d4eaae50
5 changed files with 14 additions and 0 deletions
|
@ -14,6 +14,7 @@ pub fn parse_opts(globals: &mut Globals) {
|
|||
|
||||
let max_clients = MAX_CLIENTS.to_string();
|
||||
let timeout_sec = TIMEOUT_SEC.to_string();
|
||||
let max_concurrent_streams = MAX_CONCURRENT_STREAMS.to_string();
|
||||
let min_ttl = MIN_TTL.to_string();
|
||||
let max_ttl = MAX_TTL.to_string();
|
||||
let err_ttl = ERR_TTL.to_string();
|
||||
|
@ -62,6 +63,14 @@ pub fn parse_opts(globals: &mut Globals) {
|
|||
.default_value(&max_clients)
|
||||
.help("Maximum number of simultaneous clients"),
|
||||
)
|
||||
.arg(
|
||||
Arg::with_name("max_concurrent")
|
||||
.short("C")
|
||||
.long("max-concurrent")
|
||||
.takes_value(true)
|
||||
.default_value(&max_concurrent_streams)
|
||||
.help("Maximum number of concurrent requests per client"),
|
||||
)
|
||||
.arg(
|
||||
Arg::with_name("timeout")
|
||||
.short("t")
|
||||
|
@ -152,6 +161,7 @@ pub fn parse_opts(globals: &mut Globals) {
|
|||
}
|
||||
globals.max_clients = matches.value_of("max_clients").unwrap().parse().unwrap();
|
||||
globals.timeout = Duration::from_secs(matches.value_of("timeout").unwrap().parse().unwrap());
|
||||
globals.max_concurrent_streams = matches.value_of("max_concurrent").unwrap().parse().unwrap();
|
||||
globals.min_ttl = matches.value_of("min_ttl").unwrap().parse().unwrap();
|
||||
globals.max_ttl = matches.value_of("max_ttl").unwrap().parse().unwrap();
|
||||
globals.err_ttl = matches.value_of("err_ttl").unwrap().parse().unwrap();
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
pub const LISTEN_ADDRESS: &str = "127.0.0.1:3000";
|
||||
pub const MAX_CLIENTS: usize = 512;
|
||||
pub const MAX_CONCURRENT_STREAMS: u32 = 16;
|
||||
pub const PATH: &str = "/dns-query";
|
||||
pub const SERVER_ADDRESS: &str = "9.9.9.9:53";
|
||||
pub const TIMEOUT_SEC: u64 = 10;
|
||||
|
|
|
@ -22,6 +22,7 @@ pub struct Globals {
|
|||
pub max_clients: usize,
|
||||
pub timeout: Duration,
|
||||
pub clients_count: ClientsCount,
|
||||
pub max_concurrent_streams: u32,
|
||||
pub min_ttl: u32,
|
||||
pub max_ttl: u32,
|
||||
pub err_ttl: u32,
|
||||
|
|
|
@ -287,6 +287,7 @@ impl DoH {
|
|||
|
||||
let mut server = Http::new();
|
||||
server.http1_keep_alive(self.globals.keepalive);
|
||||
server.http2_max_concurrent_streams(self.globals.max_concurrent_streams);
|
||||
server.pipeline_flush(true);
|
||||
let executor = LocalExecutor::new(self.globals.runtime_handle.clone());
|
||||
let server = server.with_executor(executor);
|
||||
|
|
|
@ -36,6 +36,7 @@ fn main() {
|
|||
max_clients: MAX_CLIENTS,
|
||||
timeout: Duration::from_secs(TIMEOUT_SEC),
|
||||
clients_count: Default::default(),
|
||||
max_concurrent_streams: MAX_CONCURRENT_STREAMS,
|
||||
min_ttl: MIN_TTL,
|
||||
max_ttl: MAX_TTL,
|
||||
err_ttl: ERR_TTL,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue