mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-01-05 03:11:39 +01:00
Merge #5095
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:
commit
a2f64f6552
@ -1,4 +1,5 @@
|
|||||||
use std::cmp::Ordering;
|
use std::cmp::Ordering;
|
||||||
|
use std::sync::atomic::AtomicBool;
|
||||||
use std::sync::{OnceLock, RwLock};
|
use std::sync::{OnceLock, RwLock};
|
||||||
use std::thread::{self, Builder};
|
use std::thread::{self, Builder};
|
||||||
|
|
||||||
@ -76,6 +77,7 @@ where
|
|||||||
SP: Fn(Progress) + Sync,
|
SP: Fn(Progress) + Sync,
|
||||||
{
|
{
|
||||||
let (extractor_sender, writer_receiver) = extractor_writer_channel(10_000);
|
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 metadata_builder = MetadataBuilder::from_index(index, wtxn)?;
|
||||||
let new_fields_ids_map = FieldIdMapWithMetadata::new(new_fields_ids_map, metadata_builder);
|
let new_fields_ids_map = FieldIdMapWithMetadata::new(new_fields_ids_map, metadata_builder);
|
||||||
@ -100,6 +102,7 @@ where
|
|||||||
thread::scope(|s| -> Result<()> {
|
thread::scope(|s| -> Result<()> {
|
||||||
let indexer_span = tracing::Span::current();
|
let indexer_span = tracing::Span::current();
|
||||||
let embedders = &embedders;
|
let embedders = &embedders;
|
||||||
|
let finished_extraction = &finished_extraction;
|
||||||
// prevent moving the field_distribution and document_ids in the inner closure...
|
// prevent moving the field_distribution and document_ids in the inner closure...
|
||||||
let field_distribution = &mut field_distribution;
|
let field_distribution = &mut field_distribution;
|
||||||
let document_ids = &mut document_ids;
|
let document_ids = &mut document_ids;
|
||||||
@ -350,6 +353,8 @@ where
|
|||||||
|
|
||||||
(indexing_context.send_progress)(Progress::from_step(Step::WritingToDatabase));
|
(indexing_context.send_progress)(Progress::from_step(Step::WritingToDatabase));
|
||||||
|
|
||||||
|
finished_extraction.store(true, std::sync::atomic::Ordering::Relaxed);
|
||||||
|
|
||||||
Result::Ok(facet_field_ids_delta)
|
Result::Ok(facet_field_ids_delta)
|
||||||
})?;
|
})?;
|
||||||
|
|
||||||
@ -384,7 +389,15 @@ where
|
|||||||
let span = tracing::trace_span!(target: "indexing::write_db", "all");
|
let span = tracing::trace_span!(target: "indexing::write_db", "all");
|
||||||
let _entered = span.enter();
|
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 {
|
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 {
|
match operation {
|
||||||
WriterOperation::DbOperation(db_operation) => {
|
WriterOperation::DbOperation(db_operation) => {
|
||||||
let database = db_operation.database(index);
|
let database = db_operation.database(index);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user