mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 05:26:27 +00:00 
			
		
		
		
	Introduce the postings lists caching stores
Currently not used
This commit is contained in:
		| @@ -1,5 +1,6 @@ | |||||||
| mod docs_words; | mod docs_words; | ||||||
| mod prefix_documents_cache; | mod prefix_documents_cache; | ||||||
|  | mod prefix_postings_lists_cache; | ||||||
| mod documents_fields; | mod documents_fields; | ||||||
| mod documents_fields_counts; | mod documents_fields_counts; | ||||||
| mod main; | mod main; | ||||||
| @@ -10,6 +11,7 @@ mod updates_results; | |||||||
|  |  | ||||||
| pub use self::docs_words::DocsWords; | pub use self::docs_words::DocsWords; | ||||||
| pub use self::prefix_documents_cache::PrefixDocumentsCache; | pub use self::prefix_documents_cache::PrefixDocumentsCache; | ||||||
|  | pub use self::prefix_postings_lists_cache::PrefixPostingsListsCache; | ||||||
| pub use self::documents_fields::{DocumentFieldsIter, DocumentsFields}; | pub use self::documents_fields::{DocumentFieldsIter, DocumentsFields}; | ||||||
| pub use self::documents_fields_counts::{ | pub use self::documents_fields_counts::{ | ||||||
|     DocumentFieldsCountsIter, DocumentsFieldsCounts, DocumentsIdsIter, |     DocumentFieldsCountsIter, DocumentsFieldsCounts, DocumentsIdsIter, | ||||||
| @@ -77,7 +79,11 @@ fn docs_words_name(name: &str) -> String { | |||||||
| } | } | ||||||
|  |  | ||||||
| fn prefix_documents_cache_name(name: &str) -> String { | fn prefix_documents_cache_name(name: &str) -> String { | ||||||
|     format!("store-{}-prefix-cache", name) |     format!("store-{}-prefix-documents-cache", name) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fn prefix_postings_lists_cache_name(name: &str) -> String { | ||||||
|  |     format!("store-{}-prefix-postings-lists-cache", name) | ||||||
| } | } | ||||||
|  |  | ||||||
| fn updates_name(name: &str) -> String { | fn updates_name(name: &str) -> String { | ||||||
| @@ -97,6 +103,7 @@ pub struct Index { | |||||||
|     pub synonyms: Synonyms, |     pub synonyms: Synonyms, | ||||||
|     pub docs_words: DocsWords, |     pub docs_words: DocsWords, | ||||||
|     pub prefix_documents_cache: PrefixDocumentsCache, |     pub prefix_documents_cache: PrefixDocumentsCache, | ||||||
|  |     pub prefix_postings_lists_cache: PrefixPostingsListsCache, | ||||||
|  |  | ||||||
|     pub updates: Updates, |     pub updates: Updates, | ||||||
|     pub updates_results: UpdatesResults, |     pub updates_results: UpdatesResults, | ||||||
| @@ -292,6 +299,7 @@ pub fn create( | |||||||
|     let synonyms_name = synonyms_name(name); |     let synonyms_name = synonyms_name(name); | ||||||
|     let docs_words_name = docs_words_name(name); |     let docs_words_name = docs_words_name(name); | ||||||
|     let prefix_documents_cache_name = prefix_documents_cache_name(name); |     let prefix_documents_cache_name = prefix_documents_cache_name(name); | ||||||
|  |     let prefix_postings_lists_cache_name = prefix_postings_lists_cache_name(name); | ||||||
|     let updates_name = updates_name(name); |     let updates_name = updates_name(name); | ||||||
|     let updates_results_name = updates_results_name(name); |     let updates_results_name = updates_results_name(name); | ||||||
|  |  | ||||||
| @@ -303,6 +311,7 @@ pub fn create( | |||||||
|     let synonyms = env.create_database(Some(&synonyms_name))?; |     let synonyms = env.create_database(Some(&synonyms_name))?; | ||||||
|     let docs_words = env.create_database(Some(&docs_words_name))?; |     let docs_words = env.create_database(Some(&docs_words_name))?; | ||||||
|     let prefix_documents_cache = env.create_database(Some(&prefix_documents_cache_name))?; |     let prefix_documents_cache = env.create_database(Some(&prefix_documents_cache_name))?; | ||||||
|  |     let prefix_postings_lists_cache = env.create_database(Some(&prefix_postings_lists_cache_name))?; | ||||||
|     let updates = update_env.create_database(Some(&updates_name))?; |     let updates = update_env.create_database(Some(&updates_name))?; | ||||||
|     let updates_results = update_env.create_database(Some(&updates_results_name))?; |     let updates_results = update_env.create_database(Some(&updates_results_name))?; | ||||||
|  |  | ||||||
| @@ -310,11 +319,10 @@ pub fn create( | |||||||
|         main: Main { main }, |         main: Main { main }, | ||||||
|         postings_lists: PostingsLists { postings_lists }, |         postings_lists: PostingsLists { postings_lists }, | ||||||
|         documents_fields: DocumentsFields { documents_fields }, |         documents_fields: DocumentsFields { documents_fields }, | ||||||
|         documents_fields_counts: DocumentsFieldsCounts { |         documents_fields_counts: DocumentsFieldsCounts { documents_fields_counts }, | ||||||
|             documents_fields_counts, |  | ||||||
|         }, |  | ||||||
|         synonyms: Synonyms { synonyms }, |         synonyms: Synonyms { synonyms }, | ||||||
|         docs_words: DocsWords { docs_words }, |         docs_words: DocsWords { docs_words }, | ||||||
|  |         prefix_postings_lists_cache: PrefixPostingsListsCache { prefix_postings_lists_cache }, | ||||||
|         prefix_documents_cache: PrefixDocumentsCache { prefix_documents_cache }, |         prefix_documents_cache: PrefixDocumentsCache { prefix_documents_cache }, | ||||||
|         updates: Updates { updates }, |         updates: Updates { updates }, | ||||||
|         updates_results: UpdatesResults { updates_results }, |         updates_results: UpdatesResults { updates_results }, | ||||||
| @@ -336,6 +344,7 @@ pub fn open( | |||||||
|     let synonyms_name = synonyms_name(name); |     let synonyms_name = synonyms_name(name); | ||||||
|     let docs_words_name = docs_words_name(name); |     let docs_words_name = docs_words_name(name); | ||||||
|     let prefix_documents_cache_name = prefix_documents_cache_name(name); |     let prefix_documents_cache_name = prefix_documents_cache_name(name); | ||||||
|  |     let prefix_postings_lists_cache_name = prefix_postings_lists_cache_name(name); | ||||||
|     let updates_name = updates_name(name); |     let updates_name = updates_name(name); | ||||||
|     let updates_results_name = updates_results_name(name); |     let updates_results_name = updates_results_name(name); | ||||||
|  |  | ||||||
| @@ -368,6 +377,10 @@ pub fn open( | |||||||
|         Some(prefix_documents_cache) => prefix_documents_cache, |         Some(prefix_documents_cache) => prefix_documents_cache, | ||||||
|         None => return Ok(None), |         None => return Ok(None), | ||||||
|     }; |     }; | ||||||
|  |     let prefix_postings_lists_cache = match env.open_database(Some(&prefix_postings_lists_cache_name))? { | ||||||
|  |         Some(prefix_postings_lists_cache) => prefix_postings_lists_cache, | ||||||
|  |         None => return Ok(None), | ||||||
|  |     }; | ||||||
|     let updates = match update_env.open_database(Some(&updates_name))? { |     let updates = match update_env.open_database(Some(&updates_name))? { | ||||||
|         Some(updates) => updates, |         Some(updates) => updates, | ||||||
|         None => return Ok(None), |         None => return Ok(None), | ||||||
| @@ -381,12 +394,11 @@ pub fn open( | |||||||
|         main: Main { main }, |         main: Main { main }, | ||||||
|         postings_lists: PostingsLists { postings_lists }, |         postings_lists: PostingsLists { postings_lists }, | ||||||
|         documents_fields: DocumentsFields { documents_fields }, |         documents_fields: DocumentsFields { documents_fields }, | ||||||
|         documents_fields_counts: DocumentsFieldsCounts { |         documents_fields_counts: DocumentsFieldsCounts { documents_fields_counts }, | ||||||
|             documents_fields_counts, |  | ||||||
|         }, |  | ||||||
|         synonyms: Synonyms { synonyms }, |         synonyms: Synonyms { synonyms }, | ||||||
|         docs_words: DocsWords { docs_words }, |         docs_words: DocsWords { docs_words }, | ||||||
|         prefix_documents_cache: PrefixDocumentsCache { prefix_documents_cache }, |         prefix_documents_cache: PrefixDocumentsCache { prefix_documents_cache }, | ||||||
|  |         prefix_postings_lists_cache: PrefixPostingsListsCache { prefix_postings_lists_cache }, | ||||||
|         updates: Updates { updates }, |         updates: Updates { updates }, | ||||||
|         updates_results: UpdatesResults { updates_results }, |         updates_results: UpdatesResults { updates_results }, | ||||||
|         updates_notifier, |         updates_notifier, | ||||||
| @@ -406,6 +418,7 @@ pub fn clear( | |||||||
|     index.synonyms.clear(writer)?; |     index.synonyms.clear(writer)?; | ||||||
|     index.docs_words.clear(writer)?; |     index.docs_words.clear(writer)?; | ||||||
|     index.prefix_documents_cache.clear(writer)?; |     index.prefix_documents_cache.clear(writer)?; | ||||||
|  |     index.prefix_postings_lists_cache.clear(writer)?; | ||||||
|     index.updates.clear(update_writer)?; |     index.updates.clear(update_writer)?; | ||||||
|     index.updates_results.clear(update_writer)?; |     index.updates_results.clear(update_writer)?; | ||||||
|     Ok(()) |     Ok(()) | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								meilisearch-core/src/store/prefix_postings_lists_cache.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								meilisearch-core/src/store/prefix_postings_lists_cache.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | use std::borrow::Cow; | ||||||
|  |  | ||||||
|  | use heed::Result as ZResult; | ||||||
|  | use heed::types::{OwnedType, CowSlice}; | ||||||
|  | use sdset::{Set, SetBuf}; | ||||||
|  |  | ||||||
|  | use crate::DocIndex; | ||||||
|  | use crate::database::MainT; | ||||||
|  |  | ||||||
|  | #[derive(Copy, Clone)] | ||||||
|  | pub struct PrefixPostingsListsCache { | ||||||
|  |     pub(crate) prefix_postings_lists_cache: heed::Database<OwnedType<[u8; 4]>, CowSlice<DocIndex>>, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl PrefixPostingsListsCache { | ||||||
|  |     pub fn put_prefix_postings_list( | ||||||
|  |         self, | ||||||
|  |         writer: &mut heed::RwTxn<MainT>, | ||||||
|  |         prefix: [u8; 4], | ||||||
|  |         postings_list: &Set<DocIndex>, | ||||||
|  |     ) -> ZResult<()> | ||||||
|  |     { | ||||||
|  |         self.prefix_postings_lists_cache.put(writer, &prefix, postings_list) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     pub fn clear(self, writer: &mut heed::RwTxn<MainT>) -> ZResult<()> { | ||||||
|  |         self.prefix_postings_lists_cache.clear(writer) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     pub fn prefix_postings_list<'txn>( | ||||||
|  |         self, | ||||||
|  |         reader: &'txn heed::RoTxn<MainT>, | ||||||
|  |         prefix: [u8; 4], | ||||||
|  |     ) -> ZResult<Option<Cow<'txn, Set<DocIndex>>>> | ||||||
|  |     { | ||||||
|  |         match self.prefix_postings_lists_cache.get(reader, &prefix)? { | ||||||
|  |             Some(Cow::Owned(vec)) => Ok(Some(Cow::Owned(SetBuf::new_unchecked(vec)))), | ||||||
|  |             Some(Cow::Borrowed(slice)) => Ok(Some(Cow::Borrowed(Set::new_unchecked(slice)))), | ||||||
|  |             None => Ok(None), | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user