mirror of
https://github.com/meilisearch/meilisearch.git
synced 2025-10-10 21:56:27 +00:00
Introduce new CLI arguments to deactivate experimental post processing
This commit is contained in:
@@ -157,7 +157,8 @@ struct WordPrefixIntegerDocids<'i> {
|
||||
database: Database<Bytes, CboRoaringBitmapCodec>,
|
||||
prefix_database: Database<Bytes, CboRoaringBitmapCodec>,
|
||||
max_memory_by_thread: Option<usize>,
|
||||
read_uncommitted_in_parallel: bool,
|
||||
/// Do not use an experimental LMDB feature to read uncommitted data in parallel.
|
||||
no_experimental_post_processing: bool,
|
||||
}
|
||||
|
||||
impl<'i> WordPrefixIntegerDocids<'i> {
|
||||
@@ -172,15 +173,11 @@ impl<'i> WordPrefixIntegerDocids<'i> {
|
||||
database,
|
||||
prefix_database,
|
||||
max_memory_by_thread: grenad_parameters.max_memory_by_thread(),
|
||||
read_uncommitted_in_parallel: false,
|
||||
no_experimental_post_processing: grenad_parameters
|
||||
.experimental_no_edition_2024_for_prefix_post_processing,
|
||||
}
|
||||
}
|
||||
|
||||
/// Use an experimental LMDB feature to read uncommitted data in parallel.
|
||||
fn read_uncommitted_in_parallel(&mut self, value: bool) {
|
||||
self.read_uncommitted_in_parallel = value;
|
||||
}
|
||||
|
||||
fn execute(
|
||||
self,
|
||||
wtxn: &mut heed::RwTxn,
|
||||
@@ -188,10 +185,10 @@ impl<'i> WordPrefixIntegerDocids<'i> {
|
||||
prefix_to_delete: &BTreeSet<Prefix>,
|
||||
) -> Result<()> {
|
||||
delete_prefixes(wtxn, &self.prefix_database, prefix_to_delete)?;
|
||||
if self.read_uncommitted_in_parallel {
|
||||
self.recompute_modified_prefixes_no_frozen(wtxn, prefix_to_compute)
|
||||
} else {
|
||||
if self.no_experimental_post_processing {
|
||||
self.recompute_modified_prefixes(wtxn, prefix_to_compute)
|
||||
} else {
|
||||
self.recompute_modified_prefixes_no_frozen(wtxn, prefix_to_compute)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -510,14 +507,13 @@ pub fn compute_word_prefix_fid_docids(
|
||||
prefix_to_delete: &BTreeSet<Prefix>,
|
||||
grenad_parameters: &GrenadParameters,
|
||||
) -> Result<()> {
|
||||
let mut builder = WordPrefixIntegerDocids::new(
|
||||
WordPrefixIntegerDocids::new(
|
||||
index,
|
||||
index.word_fid_docids.remap_key_type(),
|
||||
index.word_prefix_fid_docids.remap_key_type(),
|
||||
grenad_parameters,
|
||||
);
|
||||
builder.read_uncommitted_in_parallel(true);
|
||||
builder.execute(wtxn, prefix_to_compute, prefix_to_delete)
|
||||
)
|
||||
.execute(wtxn, prefix_to_compute, prefix_to_delete)
|
||||
}
|
||||
|
||||
#[tracing::instrument(level = "trace", skip_all, target = "indexing::prefix")]
|
||||
@@ -528,12 +524,11 @@ pub fn compute_word_prefix_position_docids(
|
||||
prefix_to_delete: &BTreeSet<Prefix>,
|
||||
grenad_parameters: &GrenadParameters,
|
||||
) -> Result<()> {
|
||||
let mut builder = WordPrefixIntegerDocids::new(
|
||||
WordPrefixIntegerDocids::new(
|
||||
index,
|
||||
index.word_position_docids.remap_key_type(),
|
||||
index.word_prefix_position_docids.remap_key_type(),
|
||||
grenad_parameters,
|
||||
);
|
||||
builder.read_uncommitted_in_parallel(true);
|
||||
builder.execute(wtxn, prefix_to_compute, prefix_to_delete)
|
||||
)
|
||||
.execute(wtxn, prefix_to_compute, prefix_to_delete)
|
||||
}
|
||||
|
Reference in New Issue
Block a user