mirror of
https://github.com/meilisearch/meilisearch.git
synced 2025-01-18 08:48:32 +08:00
Make the final merge done in parallel
This commit is contained in:
parent
91282c8b6a
commit
ecd2b2f217
@ -426,6 +426,7 @@ fn main() -> anyhow::Result<()> {
|
|||||||
|
|
||||||
let index = Index::new(&env)?;
|
let index = Index::new(&env)?;
|
||||||
|
|
||||||
|
let documents_path = opt.database.join("documents.mtbl");
|
||||||
let num_threads = rayon::current_num_threads();
|
let num_threads = rayon::current_num_threads();
|
||||||
let arc_cache_size = opt.arc_cache_size;
|
let arc_cache_size = opt.arc_cache_size;
|
||||||
let max_nb_chunks = opt.max_nb_chunks;
|
let max_nb_chunks = opt.max_nb_chunks;
|
||||||
@ -483,25 +484,29 @@ fn main() -> anyhow::Result<()> {
|
|||||||
docs_stores.push(d);
|
docs_stores.push(d);
|
||||||
});
|
});
|
||||||
|
|
||||||
debug!("We are writing into LMDB...");
|
debug!("We are writing into LMDB and MTBL...");
|
||||||
let mut wtxn = env.write_txn()?;
|
|
||||||
|
|
||||||
// We merge the postings lists into LMDB.
|
// We run both merging steps in parallel.
|
||||||
merge_into_lmdb(stores, |k, v| lmdb_writer(&mut wtxn, &index, k, v))?;
|
let (lmdb, mtbl) = rayon::join(|| {
|
||||||
|
// We merge the postings lists into LMDB.
|
||||||
|
let mut wtxn = env.write_txn()?;
|
||||||
|
merge_into_lmdb(stores, |k, v| lmdb_writer(&mut wtxn, &index, k, v))?;
|
||||||
|
Ok(wtxn.commit()?) as anyhow::Result<_>
|
||||||
|
}, || {
|
||||||
|
// We also merge the documents into its own MTBL store.
|
||||||
|
let file = OpenOptions::new().create(true).truncate(true).write(true).read(true).open(documents_path)?;
|
||||||
|
let mut writer = Writer::builder().compression_type(CompressionType::Snappy).build(file);
|
||||||
|
let mut builder = Merger::builder(docs_merge);
|
||||||
|
builder.extend(docs_stores);
|
||||||
|
builder.build().write_into(&mut writer)?;
|
||||||
|
Ok(writer.into_inner()?) as anyhow::Result<_>
|
||||||
|
});
|
||||||
|
|
||||||
// We also merge the documents into its own MTBL store.
|
let file = lmdb.and(mtbl)?;
|
||||||
let path = opt.database.join("documents.mtbl");
|
|
||||||
let file = OpenOptions::new().create(true).truncate(true).write(true).read(true).open(path)?;
|
|
||||||
let mut writer = Writer::builder().compression_type(CompressionType::Snappy).build(file);
|
|
||||||
let mut builder = Merger::builder(docs_merge);
|
|
||||||
builder.extend(docs_stores);
|
|
||||||
builder.build().write_into(&mut writer)?;
|
|
||||||
let file = writer.into_inner()?;
|
|
||||||
let mmap = unsafe { Mmap::map(&file)? };
|
let mmap = unsafe { Mmap::map(&file)? };
|
||||||
let documents = Reader::new(&mmap)?;
|
let documents = Reader::new(mmap)?;
|
||||||
let count = documents.metadata().count_entries;
|
let count = documents.metadata().count_entries;
|
||||||
|
|
||||||
wtxn.commit()?;
|
|
||||||
debug!("Wrote {} documents into LMDB", count);
|
debug!("Wrote {} documents into LMDB", count);
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
Loading…
Reference in New Issue
Block a user