Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions artifact-registry/src/client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,9 @@ pub struct ClientConfig {
pub token_source_provider: Box<dyn TokenSourceProvider>,
pub timeout: Option<Duration>,
pub connect_timeout: Option<Duration>,
pub http2_keep_alive_interval: Option<Duration>,
pub keep_alive_timeout: Option<Duration>,
pub keep_alive_while_idle: Option<bool>,
}

#[cfg(feature = "auth")]
Expand Down Expand Up @@ -56,6 +59,9 @@ impl Default for ClientConfig {
token_source_provider: Box::new(NoopTokenSourceProvider {}),
timeout: Some(Duration::from_secs(30)),
connect_timeout: Some(Duration::from_secs(30)),
http2_keep_alive_interval: None,
keep_alive_timeout: None,
keep_alive_while_idle: None,
}
}
}
Expand All @@ -70,6 +76,9 @@ impl Client {
let conn_options = ConnectionOptions {
timeout: config.timeout,
connect_timeout: config.connect_timeout,
http2_keep_alive_interval: config.http2_keep_alive_interval,
keep_alive_timeout: config.keep_alive_timeout,
keep_alive_while_idle: config.keep_alive_while_idle,
};
let conn_pool = ConnectionManager::new(
1,
Expand Down
21 changes: 21 additions & 0 deletions bigquery/src/client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,9 @@ pub struct ChannelConfig {
num_channels: usize,
connect_timeout: Option<Duration>,
timeout: Option<Duration>,
http2_keep_alive_interval: Option<Duration>,
keep_alive_timeout: Option<Duration>,
keep_alive_while_idle: Option<bool>,
}

impl ChannelConfig {
Expand All @@ -163,6 +166,18 @@ impl ChannelConfig {
self.timeout = Some(value);
self
}
pub fn with_http2_keep_alive_interval(mut self, value: Duration) -> Self {
self.http2_keep_alive_interval = Some(value);
self
}
pub fn with_keep_alive_timeout(mut self, value: Duration) -> Self {
self.keep_alive_timeout = Some(value);
self
}
pub fn with_keep_alive_while_idle(mut self, value: bool) -> Self {
self.keep_alive_while_idle = Some(value);
self
}

async fn into_connection_manager(
self,
Expand All @@ -174,6 +189,9 @@ impl ChannelConfig {
&ConnectionOptions {
timeout: self.timeout,
connect_timeout: self.connect_timeout,
http2_keep_alive_interval: self.http2_keep_alive_interval,
keep_alive_timeout: self.keep_alive_timeout,
keep_alive_while_idle: self.keep_alive_while_idle,
},
)
.await
Expand All @@ -186,6 +204,9 @@ impl Default for ChannelConfig {
num_channels: 4,
connect_timeout: Some(Duration::from_secs(30)),
timeout: None,
http2_keep_alive_interval: None,
keep_alive_timeout: None,
keep_alive_while_idle: None,
}
}
}
Expand Down
15 changes: 15 additions & 0 deletions foundation/gax/src/conn.rs
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,9 @@ where
pub struct ConnectionOptions {
pub timeout: Option<Duration>,
pub connect_timeout: Option<Duration>,
pub http2_keep_alive_interval: Option<Duration>,
pub keep_alive_timeout: Option<Duration>,
pub keep_alive_while_idle: Option<bool>,
}

impl ConnectionOptions {
Expand All @@ -110,6 +113,18 @@ impl ConnectionOptions {
Some(t) => endpoint.connect_timeout(t),
None => endpoint,
};
endpoint = match self.http2_keep_alive_interval {
Some(d) => endpoint.http2_keep_alive_interval(d),
None => endpoint,
};
endpoint = match self.keep_alive_timeout {
Some(d) => endpoint.keep_alive_timeout(d),
None => endpoint,
};
endpoint = match self.keep_alive_while_idle {
Some(v) => endpoint.keep_alive_while_idle(v),
None => endpoint,
};
endpoint
}
}
Expand Down
3 changes: 3 additions & 0 deletions spanner/src/admin/client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,9 @@ async fn internal_client(config: &AdminClientConfig) -> Result<(Channel, Operati
let conn_options = ConnectionOptions {
timeout: Some(config.timeout),
connect_timeout: Some(config.connect_timeout),
http2_keep_alive_interval: config.http2_keep_alive_interval,
keep_alive_timeout: config.keep_alive_timeout,
keep_alive_while_idle: config.keep_alive_while_idle,
};
let conn_pool = ConnectionManager::new(1, SPANNER, AUDIENCE, &config.environment, &conn_options).await?;
let conn = conn_pool.conn();
Expand Down
6 changes: 6 additions & 0 deletions spanner/src/admin/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@ pub struct AdminClientConfig {
pub timeout: Duration,
/// Timeout for establishing a new gRPC connection.
pub connect_timeout: Duration,
pub http2_keep_alive_interval: Option<Duration>,
pub keep_alive_timeout: Option<Duration>,
pub keep_alive_while_idle: Option<bool>,
}

impl Default for AdminClientConfig {
Expand All @@ -33,6 +36,9 @@ impl Default for AdminClientConfig {
},
timeout: Duration::from_secs(30),
connect_timeout: Duration::from_secs(30),
http2_keep_alive_interval: None,
keep_alive_timeout: None,
keep_alive_while_idle: None,
}
}
}
Expand Down
9 changes: 9 additions & 0 deletions spanner/src/client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,9 @@ pub struct ChannelConfig {
pub num_channels: usize,
pub connect_timeout: Duration,
pub timeout: Duration,
pub http2_keep_alive_interval: Option<Duration>,
pub keep_alive_timeout: Option<Duration>,
pub keep_alive_while_idle: Option<bool>,
}

impl Default for ChannelConfig {
Expand All @@ -66,6 +69,9 @@ impl Default for ChannelConfig {
num_channels: 4,
connect_timeout: Duration::from_secs(30),
timeout: Duration::from_secs(30),
http2_keep_alive_interval: None,
keep_alive_timeout: None,
keep_alive_while_idle: None,
}
}
}
Expand Down Expand Up @@ -197,6 +203,9 @@ impl Client {
let options = ConnectionOptions {
timeout: Some(config.channel_config.timeout),
connect_timeout: Some(config.channel_config.connect_timeout),
http2_keep_alive_interval: config.channel_config.http2_keep_alive_interval,
keep_alive_timeout: config.channel_config.keep_alive_timeout,
keep_alive_while_idle: config.channel_config.keep_alive_while_idle,
};
let conn_pool =
ConnectionManager::new(pool_size, &config.environment, config.endpoint.as_str(), &options).await?;
Expand Down
Loading