diff --git a/guide/src/qs_3_5.md b/guide/src/qs_3_5.md index 077a77315..5ab1c35be 100644 --- a/guide/src/qs_3_5.md +++ b/guide/src/qs_3_5.md @@ -134,9 +134,9 @@ for full example. Actix can wait for requests on a keep-alive connection. *Keep alive* connection behavior is defined by server settings. - * `KeepAlive::Timeout(75)` - enable 75 sec *keep alive* timer according + * `75` or `Some(75)` or `KeepAlive::Timeout(75)` - enable 75 sec *keep alive* timer according request and response settings. - * `KeepAlive::Disabled` - disable *keep alive*. + * `None` or `KeepAlive::Disabled` - disable *keep alive*. * `KeepAlive::Tcp(75)` - Use `SO_KEEPALIVE` socket option. ```rust @@ -145,10 +145,20 @@ connection behavior is defined by server settings. use actix_web::*; fn main() { + HttpServer::new(|| + Application::new() + .resource("/", |r| r.h(httpcodes::HttpOk))) + .keep_alive(75); // <- Set keep-alive to 75 seconds + HttpServer::new(|| Application::new() .resource("/", |r| r.h(httpcodes::HttpOk))) .keep_alive(server::KeepAlive::Tcp(75)); // <- Use `SO_KEEPALIVE` socket option. + + HttpServer::new(|| + Application::new() + .resource("/", |r| r.h(httpcodes::HttpOk))) + .keep_alive(None); // <- Disable keep-alive } ``` diff --git a/src/server/mod.rs b/src/server/mod.rs index b1b4793c9..d33ce7ed5 100644 --- a/src/server/mod.rs +++ b/src/server/mod.rs @@ -44,6 +44,22 @@ pub enum KeepAlive { Disabled, } +impl From for KeepAlive { + fn from(keepalive: usize) -> Self { + KeepAlive::Timeout(keepalive) + } +} + +impl From> for KeepAlive { + fn from(keepalive: Option) -> Self { + if let Some(keepalive) = keepalive { + KeepAlive::Timeout(keepalive) + } else { + KeepAlive::Disabled + } + } +} + /// Pause accepting incoming connections /// /// If socket contains some pending connection, they might be dropped. diff --git a/src/server/srv.rs b/src/server/srv.rs index d0c180b5c..f69b80359 100644 --- a/src/server/srv.rs +++ b/src/server/srv.rs @@ -124,8 +124,8 @@ impl HttpServer where H: IntoHttpHandler + 'static /// Set server keep-alive setting. /// /// By default keep alive is set to a `Os`. - pub fn keep_alive(mut self, val: KeepAlive) -> Self { - self.keep_alive = val; + pub fn keep_alive>(mut self, val: T) -> Self { + self.keep_alive = val.into(); self }