Skip to content

Commit

Permalink
Move admin server to separate OS thread (#841)
Browse files Browse the repository at this point in the history
This is to prevent heavy load on the main tasks from saturating the
workload and causing the admin server to become unresponsive, then
triggering a termination from Kubernetes.
  • Loading branch information
XAMPPRocky authored Nov 1, 2023
1 parent 67c9420 commit 80552ce
Showing 1 changed file with 24 additions and 16 deletions.
40 changes: 24 additions & 16 deletions src/cli/admin.rs
Original file line number Diff line number Diff line change
@@ -87,30 +87,38 @@ impl Admin {
&self,
config: Arc<Config>,
address: Option<std::net::SocketAddr>,
) -> tokio::task::JoinHandle<Result<(), hyper::Error>> {
) -> std::thread::JoinHandle<Result<(), hyper::Error>> {
let address = address.unwrap_or_else(|| (std::net::Ipv6Addr::UNSPECIFIED, PORT).into());
let health = Health::new();
tracing::info!(address = %address, "Starting admin endpoint");

let mode = self.clone();
let make_svc = make_service_fn(move |_conn| {
let config = config.clone();
let health = health.clone();
let mode = mode.clone();
async move {
let config = config.clone();
let health = health.clone();
let mode = mode.clone();
Ok::<_, Infallible>(service_fn(move |req| {
std::thread::spawn(move || {
let runtime = tokio::runtime::Builder::new_current_thread()
.enable_io()
.build()
.expect("couldn't create tokio runtime in thread");
runtime.block_on(async move {
let make_svc = make_service_fn(move |_conn| {
let config = config.clone();
let health = health.clone();
let mode = mode.clone();
async move { Ok::<_, Infallible>(mode.handle_request(req, config, health)) }
}))
}
});

tokio::spawn(HyperServer::bind(&address).serve(make_svc))
async move {
let config = config.clone();
let health = health.clone();
let mode = mode.clone();
Ok::<_, Infallible>(service_fn(move |req| {
let config = config.clone();
let health = health.clone();
let mode = mode.clone();
async move { Ok::<_, Infallible>(mode.handle_request(req, config, health)) }
}))
}
});

HyperServer::bind(&address).serve(make_svc).await
})
})
}

fn is_ready(&self, config: &Config) -> bool {

0 comments on commit 80552ce

Please sign in to comment.