Expand description
A library for gracefully shutting down asynchronous applications
This may be useful when you want to allow all in-flight processing to complete before shutting down in order to maintain a consistent state.
§Examples
use shutdown_async::ShutdownController;
#[tokio::main]
async fn main() {
let shutdown = ShutdownController::new();
tokio::task::spawn({
let mut monitor = shutdown.subscribe();
async move {
// Wait for something to happen
tokio::select! {
_ = monitor.recv() => { println!("shutdown initiated"); }
_ = tokio::time::sleep(ONE_YEAR) => { println!("one year has passed!"); }
}
}
});
shutdown.shutdown().await;
}
static ONE_YEAR: std::time::Duration = std::time::Duration::from_secs(60 * 60 * 24 * 365);
Structs§
- Shutdown
Controller - A
ShutdownController
is used to control the shutdown of an application. - Shutdown
Monitor - A
ShutdownMonitor
listens for the shutdown signal from aShutdownController
and tracks that the signal has been received.