From 4cee9e0de1f1bb3eb2d18ca4993f66e0859317e2 Mon Sep 17 00:00:00 2001 From: Richard Hua Date: Wed, 4 Oct 2023 14:25:03 -0700 Subject: [PATCH] Set timeout and keep alive options --- xmtp_networking/src/grpc_api_helper.rs | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/xmtp_networking/src/grpc_api_helper.rs b/xmtp_networking/src/grpc_api_helper.rs index 645e67d94..4fecf7889 100644 --- a/xmtp_networking/src/grpc_api_helper.rs +++ b/xmtp_networking/src/grpc_api_helper.rs @@ -32,7 +32,7 @@ fn tls_config() -> ClientConfig { .with_no_client_auth() } -fn get_tls_connector() -> HttpsConnector { +fn get_tls_connector() -> HttpsConnector> { let tls = tls_config(); let mut http = HttpConnector::new(); @@ -46,6 +46,7 @@ fn get_tls_connector() -> HttpsConnector { .enable_http2() .wrap_connector(s) }) + .timeout(Duration::from_secs(5)) .service(http) } @@ -53,7 +54,10 @@ pub enum InnerApiClient { Plain(MessageApiClient), Tls( MessageApiClient< - hyper::Client, UnsyncBoxBody>, + hyper::Client< + HttpsConnector>, + UnsyncBoxBody, + >, >, ), } @@ -69,7 +73,11 @@ impl Client { if is_secure { let connector = get_tls_connector(); - let tls_conn = hyper::Client::builder().build(connector); + let tls_conn = hyper::Client::builder() + .pool_idle_timeout(Duration::from_secs(30)) + .http2_keep_alive_interval(Duration::from_secs(10)) + .http2_keep_alive_timeout(Duration::from_secs(5)) + .build(connector); let uri = Uri::from_str(&host).map_err(|e| Error::new(ErrorKind::SetupError).with(e))?; @@ -83,6 +91,11 @@ impl Client { } else { let channel = Channel::from_shared(host) .map_err(|e| Error::new(ErrorKind::SetupError).with(e))? + .timeout(Duration::from_secs(5)) + .connect_timeout(Duration::from_secs(5)) + .tcp_keepalive(Some(Duration::from_secs(10))) + .http2_keep_alive_interval(Duration::from_secs(10)) + .keep_alive_timeout(Duration::from_secs(5)) .connect() .await .map_err(|e| Error::new(ErrorKind::SetupError).with(e))?; @@ -123,7 +136,6 @@ impl XmtpApiClient for Client { .map_err(|e| Error::new(ErrorKind::PublishError).with(e))?; let mut tonic_request = Request::new(request); - tonic_request.set_timeout(Duration::from_secs(5)); tonic_request.metadata_mut().insert("authorization", token); tonic_request .metadata_mut() @@ -171,7 +183,6 @@ impl XmtpApiClient for Client { async fn query(&self, request: QueryRequest) -> Result { let mut tonic_request = Request::new(request); - tonic_request.set_timeout(Duration::from_secs(5)); tonic_request .metadata_mut() .insert("x-app-version", self.app_version.clone()); @@ -193,7 +204,6 @@ impl Client { request: BatchQueryRequest, ) -> Result { let mut tonic_request = Request::new(request); - tonic_request.set_timeout(Duration::from_secs(5)); tonic_request .metadata_mut() .insert("x-app-version", self.app_version.clone());