mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Merge #5095
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Test suite / Tests on ${{ matrix.os }} (macos-13) (push) Waiting to run
				
					
					
				
			
		
			
				
	
				Test suite / Tests almost all features (push) Has been skipped
				
					
					
				
			
		
			
				
	
				Test suite / Test disabled tokenization (push) Has been skipped
				
					
					
				
			
		
			
				
	
				Test suite / Tests on ubuntu-20.04 (push) Failing after 13s
				
					
					
				
			
		
			
				
	
				Test suite / Run tests in debug (push) Failing after 12s
				
					
					
				
			
		
			
				
	
				Test suite / Tests on ${{ matrix.os }} (windows-2022) (push) Failing after 40s
				
					
					
				
			
		
			
				
	
				Test suite / Run Rustfmt (push) Successful in 1m46s
				
					
					
				
			
		
			
				
	
				Test suite / Run Clippy (push) Successful in 9m55s
				
					
					
				
			
		
		
	
	
				
					
				
			
		
			Some checks failed
		
		
	
	Test suite / Tests on ${{ matrix.os }} (macos-13) (push) Waiting to run
				Test suite / Tests almost all features (push) Has been skipped
				Test suite / Test disabled tokenization (push) Has been skipped
				Test suite / Tests on ubuntu-20.04 (push) Failing after 13s
				Test suite / Run tests in debug (push) Failing after 12s
				Test suite / Tests on ${{ matrix.os }} (windows-2022) (push) Failing after 40s
				Test suite / Run Rustfmt (push) Successful in 1m46s
				Test suite / Run Clippy (push) Successful in 9m55s
				5095: Span to measure the part of db writes that is after the merge/extraction r=curquiza a=dureuill Co-authored-by: Louis Dureuil <louis@meilisearch.com>
This commit is contained in:
		| @@ -1,4 +1,5 @@ | ||||
| use std::cmp::Ordering; | ||||
| use std::sync::atomic::AtomicBool; | ||||
| use std::sync::{OnceLock, RwLock}; | ||||
| use std::thread::{self, Builder}; | ||||
|  | ||||
| @@ -76,6 +77,7 @@ where | ||||
|     SP: Fn(Progress) + Sync, | ||||
| { | ||||
|     let (extractor_sender, writer_receiver) = extractor_writer_channel(10_000); | ||||
|     let finished_extraction = AtomicBool::new(false); | ||||
|  | ||||
|     let metadata_builder = MetadataBuilder::from_index(index, wtxn)?; | ||||
|     let new_fields_ids_map = FieldIdMapWithMetadata::new(new_fields_ids_map, metadata_builder); | ||||
| @@ -100,6 +102,7 @@ where | ||||
|     thread::scope(|s| -> Result<()> { | ||||
|         let indexer_span = tracing::Span::current(); | ||||
|         let embedders = &embedders; | ||||
|         let finished_extraction = &finished_extraction; | ||||
|         // prevent moving the field_distribution and document_ids in the inner closure... | ||||
|         let field_distribution = &mut field_distribution; | ||||
|         let document_ids = &mut document_ids; | ||||
| @@ -350,6 +353,8 @@ where | ||||
|  | ||||
|             (indexing_context.send_progress)(Progress::from_step(Step::WritingToDatabase)); | ||||
|  | ||||
|             finished_extraction.store(true, std::sync::atomic::Ordering::Relaxed); | ||||
|  | ||||
|             Result::Ok(facet_field_ids_delta) | ||||
|         })?; | ||||
|  | ||||
| @@ -384,7 +389,15 @@ where | ||||
|             let span = tracing::trace_span!(target: "indexing::write_db", "all"); | ||||
|             let _entered = span.enter(); | ||||
|  | ||||
|             let span = tracing::trace_span!(target: "indexing::write_db", "post_merge"); | ||||
|             let mut _entered_post_merge = None; | ||||
|  | ||||
|             for operation in writer_receiver { | ||||
|                 if _entered_post_merge.is_none() | ||||
|                     && finished_extraction.load(std::sync::atomic::Ordering::Relaxed) | ||||
|                 { | ||||
|                     _entered_post_merge = Some(span.enter()); | ||||
|                 } | ||||
|                 match operation { | ||||
|                     WriterOperation::DbOperation(db_operation) => { | ||||
|                         let database = db_operation.database(index); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user