mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Introduce the ThreadPoolNoAbort wrapper
This commit is contained in:
		| @@ -6,7 +6,6 @@ use std::num::ParseIntError; | ||||
| use std::ops::Deref; | ||||
| use std::path::PathBuf; | ||||
| use std::str::FromStr; | ||||
| use std::sync::atomic::{AtomicBool, Ordering}; | ||||
| use std::sync::Arc; | ||||
| use std::{env, fmt, fs}; | ||||
|  | ||||
| @@ -14,6 +13,7 @@ use byte_unit::{Byte, ByteError}; | ||||
| use clap::Parser; | ||||
| use meilisearch_types::features::InstanceTogglableFeatures; | ||||
| use meilisearch_types::milli::update::IndexerConfig; | ||||
| use meilisearch_types::milli::ThreadPoolNoAbortBuilder; | ||||
| use rustls::server::{ | ||||
|     AllowAnyAnonymousOrAuthenticatedClient, AllowAnyAuthenticatedClient, ServerSessionMemoryCache, | ||||
| }; | ||||
| @@ -667,23 +667,15 @@ impl TryFrom<&IndexerOpts> for IndexerConfig { | ||||
|     type Error = anyhow::Error; | ||||
|  | ||||
|     fn try_from(other: &IndexerOpts) -> Result<Self, Self::Error> { | ||||
|         let pool_panic_catched = Arc::new(AtomicBool::new(false)); | ||||
|         let thread_pool = rayon::ThreadPoolBuilder::new() | ||||
|         let thread_pool = ThreadPoolNoAbortBuilder::new() | ||||
|             .thread_name(|index| format!("indexing-thread:{index}")) | ||||
|             .num_threads(*other.max_indexing_threads) | ||||
|             .panic_handler({ | ||||
|                 // TODO What should we do with this Box<dyn Any + Send>. | ||||
|                 //      So, let's just set a value to true to cancel the task with a message for now. | ||||
|                 let panic_cathed = pool_panic_catched.clone(); | ||||
|                 move |_result| panic_cathed.store(true, Ordering::SeqCst) | ||||
|             }) | ||||
|             .build()?; | ||||
|  | ||||
|         Ok(Self { | ||||
|             log_every_n: Some(DEFAULT_LOG_EVERY_N), | ||||
|             max_memory: other.max_indexing_memory.map(|b| b.get_bytes() as usize), | ||||
|             thread_pool: Some(thread_pool), | ||||
|             pool_panic_catched, | ||||
|             max_positions_per_attributes: None, | ||||
|             skip_index_budget: other.skip_index_budget, | ||||
|             ..Default::default() | ||||
|   | ||||
		Reference in New Issue
	
	Block a user