mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 04:56:28 +00:00 
			
		
		
		
	Merge #4861
4861: Make sure the index scheduler never stops running r=irevoire a=irevoire # Pull Request ## Related issue Fixes https://github.com/meilisearch/meilisearch/issues/4748 ## What does this PR do? - Whatever happens, we always try to process tasks once every minute (if no tasks are enqueued that's practically free) Co-authored-by: Tamo <tamo@meilisearch.com>
This commit is contained in:
		| @@ -35,6 +35,7 @@ pub type TaskId = u32; | ||||
| use std::collections::{BTreeMap, HashMap}; | ||||
| use std::io::{self, BufReader, Read}; | ||||
| use std::ops::{Bound, RangeBounds}; | ||||
| use std::panic::{catch_unwind, AssertUnwindSafe}; | ||||
| use std::path::{Path, PathBuf}; | ||||
| use std::sync::atomic::Ordering::{self, Relaxed}; | ||||
| use std::sync::atomic::{AtomicBool, AtomicU32}; | ||||
| @@ -612,19 +613,24 @@ impl IndexScheduler { | ||||
|                 #[cfg(test)] | ||||
|                 run.breakpoint(Breakpoint::Init); | ||||
|  | ||||
|                 run.wake_up.wait(); | ||||
|                 run.wake_up.wait_timeout(std::time::Duration::from_secs(60)); | ||||
|  | ||||
|                 loop { | ||||
|                     match run.tick() { | ||||
|                         Ok(TickOutcome::TickAgain(_)) => (), | ||||
|                         Ok(TickOutcome::WaitForSignal) => run.wake_up.wait(), | ||||
|                         Err(e) => { | ||||
|                     let ret = catch_unwind(AssertUnwindSafe(|| run.tick())); | ||||
|                     match ret { | ||||
|                         Ok(Ok(TickOutcome::TickAgain(_))) => (), | ||||
|                         Ok(Ok(TickOutcome::WaitForSignal)) => run.wake_up.wait(), | ||||
|                         Ok(Err(e)) => { | ||||
|                             tracing::error!("{e}"); | ||||
|                             // Wait one second when an irrecoverable error occurs. | ||||
|                             if !e.is_recoverable() { | ||||
|                                 std::thread::sleep(Duration::from_secs(1)); | ||||
|                             } | ||||
|                         } | ||||
|                         Err(_panic) => { | ||||
|                             tracing::error!("Internal error: Unexpected panic in the `IndexScheduler::run` method."); | ||||
|  | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             }) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user