Skip to content

Commit

Permalink
Add health checks for each service
Browse files Browse the repository at this point in the history
  • Loading branch information
XAMPPRocky committed Sep 27, 2023
1 parent 1d2bec6 commit a160fc7
Show file tree
Hide file tree
Showing 19 changed files with 535 additions and 269 deletions.
3 changes: 2 additions & 1 deletion benches/throughput.rs
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,8 @@ fn run_quilkin(port: u16, endpoint: SocketAddr) {

runtime.block_on(async move {
let (_shutdown_tx, shutdown_rx) = tokio::sync::watch::channel::<()>(());
proxy.run(config, shutdown_rx).await.unwrap();
let admin = quilkin::cli::Admin::Proxy(<_>::default());
proxy.run(config, admin, shutdown_rx).await.unwrap();
});
});
}
Expand Down
4 changes: 3 additions & 1 deletion examples/quilkin-filter-example/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,8 @@ async fn main() -> quilkin::Result<()> {
)
});

proxy.run(config.into(), shutdown_rx).await
let admin = quilkin::cli::Admin::Proxy(<_>::default());

proxy.run(config.into(), admin, shutdown_rx).await
}
// ANCHOR_END: run
160 changes: 0 additions & 160 deletions src/admin.rs

This file was deleted.

84 changes: 53 additions & 31 deletions src/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@
* limitations under the License.
*/

pub(crate) mod admin;

use std::{
path::{Path, PathBuf},
sync::Arc,
Expand All @@ -23,12 +25,12 @@ use clap::builder::TypedValueParser;
use clap::crate_version;
use tokio::{signal, sync::watch};

use crate::{admin::Mode, Config};
use crate::Config;
use strum_macros::{Display, EnumString};

pub use self::{
agent::Agent, generate_config_schema::GenerateConfigSchema, manage::Manage, proxy::Proxy,
qcmp::Qcmp, relay::Relay,
admin::Admin, agent::Agent, generate_config_schema::GenerateConfigSchema, manage::Manage,
proxy::Proxy, qcmp::Qcmp, relay::Relay,
};

macro_rules! define_port {
Expand Down Expand Up @@ -106,10 +108,21 @@ pub enum Commands {
}

impl Commands {
pub fn admin_mode(&self) -> Option<Mode> {
pub fn admin_mode(&self) -> Option<Admin> {
match self {
Self::Proxy(_) | Self::Agent(_) => Some(Mode::Proxy),
Self::Relay(_) | Self::Manage(_) => Some(Mode::Xds),
Self::Proxy(proxy) => Some(Admin::Proxy(proxy::RuntimeConfig {
idle_request_interval_secs: proxy.idle_request_interval_secs,
..<_>::default()
})),
Self::Agent(agent) => Some(Admin::Agent(agent::RuntimeConfig {
idle_request_interval_secs: agent.idle_request_interval_secs,
..<_>::default()
})),
Self::Relay(relay) => Some(Admin::Relay(relay::RuntimeConfig {
idle_request_interval_secs: relay.idle_request_interval_secs,
..<_>::default()
})),
Self::Manage(_) => Some(Admin::Xds(<_>::default())),
Self::GenerateConfigSchema(_) | Self::Qcmp(_) => None,
}
}
Expand Down Expand Up @@ -148,24 +161,24 @@ impl Cli {
"Starting Quilkin"
);

if let Commands::Qcmp(Qcmp::Ping(ping)) = self.command {
return ping.run().await;
// Non-long running commands (e.g. ones with no administration server)
// are executed here.
match self.command {
Commands::Qcmp(Qcmp::Ping(ping)) => return ping.run().await,
Commands::GenerateConfigSchema(generator) => {
return generator.generate_config_schema();
}
_ => {}
}

tracing::debug!(cli = ?self, "config parameters");

let config = Arc::new(Self::read_config(self.config)?);
let _admin_task = self
.command
.admin_mode()
.filter(|_| !self.no_admin)
.map(|mode| {
tokio::spawn(crate::admin::server(
mode,
config.clone(),
self.admin_address,
))
});
let mode = self.command.admin_mode().unwrap();

if !self.no_admin {
mode.server(config.clone(), self.admin_address);
}

let (shutdown_tx, shutdown_rx) = watch::channel::<()>(());

Expand All @@ -191,37 +204,45 @@ impl Cli {

let fut = tryhard::retry_fn({
let shutdown_rx = shutdown_rx.clone();
let mode = mode.clone();
move || match self.command.clone() {
Commands::Agent(agent) => {
let config = config.clone();
let shutdown_rx = shutdown_rx.clone();
tokio::spawn(
async move { agent.run(config.clone(), shutdown_rx.clone()).await },
)
let mode = mode.clone();
tokio::spawn(async move {
agent.run(config.clone(), mode, shutdown_rx.clone()).await
})
}
Commands::Proxy(runner) => {
let config = config.clone();
let shutdown_rx = shutdown_rx.clone();
tokio::spawn(
async move { runner.run(config.clone(), shutdown_rx.clone()).await },
)
let mode = mode.clone();
tokio::spawn(async move {
runner
.run(config.clone(), mode.clone(), shutdown_rx.clone())
.await
})
}
Commands::Manage(manager) => {
let config = config.clone();
let shutdown_rx = shutdown_rx.clone();
let mode = mode.clone();
tokio::spawn(async move {
manager.manage(config.clone(), shutdown_rx.clone()).await
manager
.manage(config.clone(), mode, shutdown_rx.clone())
.await
})
}
Commands::GenerateConfigSchema(generator) => {
tokio::spawn(std::future::ready(generator.generate_config_schema()))
}
Commands::Relay(relay) => {
let config = config.clone();
let shutdown_rx = shutdown_rx.clone();
tokio::spawn(async move { relay.relay(config, shutdown_rx.clone()).await })
let mode = mode.clone();
tokio::spawn(
async move { relay.relay(config, mode, shutdown_rx.clone()).await },
)
}
Commands::Qcmp(_) => unreachable!(),
Commands::GenerateConfigSchema(_) | Commands::Qcmp(_) => unreachable!(),
}
})
.retries(3)
Expand Down Expand Up @@ -354,6 +375,7 @@ mod tests {
region: None,
sub_zone: None,
zone: None,
idle_request_interval_secs: admin::IDLE_REQUEST_INTERVAL_SECS,
qcmp_port: crate::test_utils::available_addr(&AddressType::Random)
.await
.port(),
Expand Down
Loading

0 comments on commit a160fc7

Please sign in to comment.