Skip to content

Commit

Permalink
chore: auto restart services
Browse files Browse the repository at this point in the history
  • Loading branch information
tobi-bams committed Dec 3, 2024
1 parent b56b56f commit a12bb3f
Show file tree
Hide file tree
Showing 3 changed files with 84 additions and 1 deletion.
75 changes: 75 additions & 0 deletions src/auto_restart_cron.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
use std::sync::atomic::{AtomicBool, Ordering};

use anyhow::{anyhow, Error, Result};
use bollard::Docker;
use tokio_cron_scheduler::{Job, JobScheduler};

use crate::{config::STATE, dock::restart_node_container, utils::getenv};

pub static RESTART_SERVICES: AtomicBool = AtomicBool::new(false);

pub async fn auto_restart_cron(
proj: String,
docker: Docker,
auto_restart_services: Vec<String>,
) -> Result<JobScheduler> {
log::info!("Auto Restart Services");
let sched = JobScheduler::new().await?;

let cron_time = match getenv("AUTO_RESTART_CRON_TIME") {
Ok(env) => env,
Err(_) => "@daily".to_string(),
};

sched
.add(Job::new_async(cron_time.as_str(), |_uuid, _l| {
Box::pin(async move {
if !RESTART_SERVICES.load(Ordering::Relaxed) {
RESTART_SERVICES.store(true, Ordering::Relaxed);
}
})
})?)
.await?;

sched.start().await?;

tokio::spawn(async move {
loop {
let go = RESTART_SERVICES.load(Ordering::Relaxed);
if go {
if let Err(e) =
auto_restart_services_handler(&proj, &docker, auto_restart_services.clone())
.await
{
log::error!("Error auto restarting services: {:?}", e);
}

RESTART_SERVICES.store(false, Ordering::Relaxed);
}
tokio::time::sleep(std::time::Duration::from_secs(10)).await;
}
});

Ok(sched)
}

async fn auto_restart_services_handler(
proj: &str,
docker: &Docker,
auto_restart_services: Vec<String>,
) -> Result<(), Error> {
let mut state = STATE.lock().await;
let mut err_vec: Vec<String> = Vec::new();
for service in auto_restart_services {
log::info!("About to auto restart {}", service);
match restart_node_container(docker, &service, &mut state, proj).await {
Ok(()) => {}
Err(err) => err_vec.push(format!("{}: {}", service, err.to_string())),
}
}
if err_vec.is_empty() {
return Ok(());
}

Err(anyhow!(err_vec.join("\n")))
}
9 changes: 8 additions & 1 deletion src/bin/stack/mod.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use anyhow::Result;
use rocket::tokio;
use sphinx_swarm::auto_restart_cron::auto_restart_cron;
use sphinx_swarm::backup::backup_and_delete_volumes_cron;
use sphinx_swarm::builder;
use sphinx_swarm::config::{load_config_file, put_config_file, Stack};
Expand Down Expand Up @@ -59,7 +60,7 @@ async fn main() -> Result<()> {
handler::hydrate_clients(clients).await;

if let Some(nn) = stack.auto_update {
let cron_handler_res = builder::auto_updater(proj, docker, nn).await;
let cron_handler_res = builder::auto_updater(proj, docker.clone(), nn).await;
if let Err(e) = cron_handler_res {
log::error!("CRON failed {:?}", e);
}
Expand All @@ -71,6 +72,12 @@ async fn main() -> Result<()> {
log::info!("BACKUP is not set!!")
}

if let Some(auto_restart_services) = stack.auto_restart {
auto_restart_cron(proj.to_string(), docker, auto_restart_services).await?;
} else {
log::info!("Auto Restart not set")
}

tokio::signal::ctrl_c().await?;

builder::shutdown_now();
Expand Down
1 change: 1 addition & 0 deletions src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
pub mod app_login;
pub mod auth;
pub mod auto_restart_cron;
pub mod backup;
pub mod builder;
pub mod cmd;
Expand Down

0 comments on commit a12bb3f

Please sign in to comment.