mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	remove heed from http dependencies
This commit is contained in:
		
							
								
								
									
										1
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -1698,7 +1698,6 @@ dependencies = [ | |||||||
|  "crossbeam-channel", |  "crossbeam-channel", | ||||||
|  "env_logger", |  "env_logger", | ||||||
|  "futures", |  "futures", | ||||||
|  "heed", |  | ||||||
|  "http 0.1.21", |  "http 0.1.21", | ||||||
|  "http-service", |  "http-service", | ||||||
|  "http-service-mock", |  "http-service-mock", | ||||||
|   | |||||||
| @@ -8,10 +8,10 @@ use chrono::{DateTime, Utc}; | |||||||
| use crossbeam_channel::{Receiver, Sender}; | use crossbeam_channel::{Receiver, Sender}; | ||||||
| use heed::types::{Str, Unit, SerdeBincode}; | use heed::types::{Str, Unit, SerdeBincode}; | ||||||
| use heed::{CompactionOption, Result as ZResult}; | use heed::{CompactionOption, Result as ZResult}; | ||||||
| use log::debug; | use log::{debug, error}; | ||||||
| use meilisearch_schema::Schema; | use meilisearch_schema::Schema; | ||||||
|  |  | ||||||
| use crate::{store, update, Index, MResult, Error}; | use crate::{store, update, Index, MResult, Error, UpdateReader, MainWriter}; | ||||||
|  |  | ||||||
| pub type BoxUpdateFn = Box<dyn Fn(&str, update::ProcessedUpdateResult) + Send + Sync + 'static>; | pub type BoxUpdateFn = Box<dyn Fn(&str, update::ProcessedUpdateResult) + Send + Sync + 'static>; | ||||||
| type ArcSwapFn = arc_swap::ArcSwapOption<BoxUpdateFn>; | type ArcSwapFn = arc_swap::ArcSwapOption<BoxUpdateFn>; | ||||||
| @@ -247,6 +247,13 @@ impl Database { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     pub fn is_indexing(&self, reader: &UpdateReader, index: &str) -> MResult<Option<bool>> { | ||||||
|  |         match self.open_index(&index) { | ||||||
|  |             Some(index) => index.current_update_id(&reader).map(|u| Some(u.is_some())), | ||||||
|  |             None => Ok(None), | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     pub fn create_index(&self, name: impl AsRef<str>) -> MResult<Index> { |     pub fn create_index(&self, name: impl AsRef<str>) -> MResult<Index> { | ||||||
|         let name = name.as_ref(); |         let name = name.as_ref(); | ||||||
|         let mut indexes_lock = self.indexes.write().unwrap(); |         let mut indexes_lock = self.indexes.write().unwrap(); | ||||||
| @@ -449,6 +456,44 @@ impl Database { | |||||||
|         let common_store = self.common_store(); |         let common_store = self.common_store(); | ||||||
|         Ok(common_store.get::<_, Str, Unit>(&reader, UNHEALTHY_KEY)?) |         Ok(common_store.get::<_, Str, Unit>(&reader, UNHEALTHY_KEY)?) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     pub fn compute_stats(&self, writer: &mut MainWriter, index_uid: &str) -> MResult<()> { | ||||||
|  |         let index = match self.open_index(&index_uid) { | ||||||
|  |             Some(index) => index, | ||||||
|  |             None => { | ||||||
|  |                 error!("Impossible to retrieve index {}", index_uid); | ||||||
|  |                 return Ok(()); | ||||||
|  |             } | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         let schema = match index.main.schema(&writer)? { | ||||||
|  |             Some(schema) => schema, | ||||||
|  |             None => return Ok(()), | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         let all_documents_fields = index | ||||||
|  |             .documents_fields_counts | ||||||
|  |             .all_documents_fields_counts(&writer)?; | ||||||
|  |  | ||||||
|  |         // count fields frequencies | ||||||
|  |         let mut fields_frequency = HashMap::<_, usize>::new(); | ||||||
|  |         for result in all_documents_fields { | ||||||
|  |             let (_, attr, _) = result?; | ||||||
|  |             if let Some(field_id) = schema.indexed_pos_to_field_id(attr) { | ||||||
|  |                 *fields_frequency.entry(field_id).or_default() += 1; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // convert attributes to their names | ||||||
|  |         let frequency: HashMap<_, _> = fields_frequency | ||||||
|  |             .into_iter() | ||||||
|  |             .filter_map(|(a, c)| schema.name(a).map(|name| (name.to_string(), c))) | ||||||
|  |             .collect(); | ||||||
|  |  | ||||||
|  |         index | ||||||
|  |             .main | ||||||
|  |             .put_fields_frequency(writer, &frequency) | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
|   | |||||||
| @@ -52,6 +52,12 @@ use crate::reordered_attrs::ReorderedAttrs; | |||||||
| type FstSetCow<'a> = fst::Set<Cow<'a, [u8]>>; | type FstSetCow<'a> = fst::Set<Cow<'a, [u8]>>; | ||||||
| type FstMapCow<'a> = fst::Map<Cow<'a, [u8]>>; | type FstMapCow<'a> = fst::Map<Cow<'a, [u8]>>; | ||||||
|  |  | ||||||
|  | pub type MainWriter<'a> = heed::RwTxn<'a, MainT>; | ||||||
|  | pub type MainReader = heed::RoTxn<MainT>; | ||||||
|  |  | ||||||
|  | pub type UpdateWriter<'a> = heed::RwTxn<'a, UpdateT>; | ||||||
|  | pub type UpdateReader = heed::RoTxn<UpdateT>; | ||||||
|  |  | ||||||
| #[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord)] | #[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord)] | ||||||
| pub struct Document { | pub struct Document { | ||||||
|     pub id: DocumentId, |     pub id: DocumentId, | ||||||
|   | |||||||
| @@ -29,7 +29,6 @@ chrono = { version = "0.4.11", features = ["serde"] } | |||||||
| crossbeam-channel = "0.4.2" | crossbeam-channel = "0.4.2" | ||||||
| env_logger = "0.7.1" | env_logger = "0.7.1" | ||||||
| futures = "0.3.4" | futures = "0.3.4" | ||||||
| heed = "0.8.0" |  | ||||||
| http = "0.1.19" | http = "0.1.19" | ||||||
| indexmap = { version = "1.3.2", features = ["serde-1"] } | indexmap = { version = "1.3.2", features = ["serde-1"] } | ||||||
| log = "0.4.8" | log = "0.4.8" | ||||||
|   | |||||||
| @@ -1,9 +1,7 @@ | |||||||
| use std::collections::HashMap; |  | ||||||
| use std::ops::Deref; | use std::ops::Deref; | ||||||
| use std::sync::Arc; | use std::sync::Arc; | ||||||
|  |  | ||||||
| use log::error; | use meilisearch_core::{Database, DatabaseOptions}; | ||||||
| use meilisearch_core::{Database, DatabaseOptions, MResult, MainT, UpdateT}; |  | ||||||
| use sha2::Digest; | use sha2::Digest; | ||||||
| use sysinfo::Pid; | use sysinfo::Pid; | ||||||
|  |  | ||||||
| @@ -56,53 +54,6 @@ impl ApiKeys { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| impl DataInner { |  | ||||||
|     pub fn is_indexing(&self, reader: &heed::RoTxn<UpdateT>, index: &str) -> MResult<Option<bool>> { |  | ||||||
|         match self.db.open_index(&index) { |  | ||||||
|             Some(index) => index.current_update_id(&reader).map(|u| Some(u.is_some())), |  | ||||||
|             None => Ok(None), |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     pub fn compute_stats(&self, writer: &mut heed::RwTxn<MainT>, index_uid: &str) -> MResult<()> { |  | ||||||
|         let index = match self.db.open_index(&index_uid) { |  | ||||||
|             Some(index) => index, |  | ||||||
|             None => { |  | ||||||
|                 error!("Impossible to retrieve index {}", index_uid); |  | ||||||
|                 return Ok(()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
|  |  | ||||||
|         let schema = match index.main.schema(&writer)? { |  | ||||||
|             Some(schema) => schema, |  | ||||||
|             None => return Ok(()), |  | ||||||
|         }; |  | ||||||
|  |  | ||||||
|         let all_documents_fields = index |  | ||||||
|             .documents_fields_counts |  | ||||||
|             .all_documents_fields_counts(&writer)?; |  | ||||||
|  |  | ||||||
|         // count fields frequencies |  | ||||||
|         let mut fields_distribution = HashMap::<_, usize>::new(); |  | ||||||
|         for result in all_documents_fields { |  | ||||||
|             let (_, attr, _) = result?; |  | ||||||
|             if let Some(field_id) = schema.indexed_pos_to_field_id(attr) { |  | ||||||
|                 *fields_distribution.entry(field_id).or_default() += 1; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // convert attributes to their names |  | ||||||
|         let distribution: HashMap<_, _> = fields_distribution |  | ||||||
|             .into_iter() |  | ||||||
|             .filter_map(|(a, c)| schema.name(a).map(|name| (name.to_string(), c))) |  | ||||||
|             .collect(); |  | ||||||
|  |  | ||||||
|         index |  | ||||||
|             .main |  | ||||||
|             .put_fields_distribution(writer, &distribution) |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| impl Data { | impl Data { | ||||||
|     pub fn new(opt: Opt) -> Data { |     pub fn new(opt: Opt) -> Data { | ||||||
|         let db_path = opt.db_path.clone(); |         let db_path = opt.db_path.clone(); | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ use std::time::Instant; | |||||||
|  |  | ||||||
| use indexmap::IndexMap; | use indexmap::IndexMap; | ||||||
| use log::error; | use log::error; | ||||||
| use meilisearch_core::Filter; | use meilisearch_core::{Filter, MainReader}; | ||||||
| use meilisearch_core::facets::FacetFilter; | use meilisearch_core::facets::FacetFilter; | ||||||
| use meilisearch_core::criterion::*; | use meilisearch_core::criterion::*; | ||||||
| use meilisearch_core::settings::RankingRule; | use meilisearch_core::settings::RankingRule; | ||||||
| use meilisearch_core::{Highlight, Index, MainT, RankedMap}; | use meilisearch_core::{Highlight, Index, RankedMap}; | ||||||
| use meilisearch_schema::{FieldId, Schema}; | use meilisearch_schema::{FieldId, Schema}; | ||||||
| use meilisearch_tokenizer::is_cjk; | use meilisearch_tokenizer::is_cjk; | ||||||
| use serde::{Deserialize, Serialize}; | use serde::{Deserialize, Serialize}; | ||||||
| @@ -107,7 +107,7 @@ impl<'a> SearchBuilder<'a> { | |||||||
|         self |         self | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn search(self, reader: &heed::RoTxn<MainT>) -> Result<SearchResult, ResponseError> { |     pub fn search(self, reader: &MainReader) -> Result<SearchResult, ResponseError> { | ||||||
|         let schema = self |         let schema = self | ||||||
|             .index |             .index | ||||||
|             .main |             .main | ||||||
| @@ -257,7 +257,7 @@ impl<'a> SearchBuilder<'a> { | |||||||
|  |  | ||||||
|     pub fn get_criteria( |     pub fn get_criteria( | ||||||
|         &self, |         &self, | ||||||
|         reader: &heed::RoTxn<MainT>, |         reader: &MainReader, | ||||||
|         ranked_map: &'a RankedMap, |         ranked_map: &'a RankedMap, | ||||||
|         schema: &Schema, |         schema: &Schema, | ||||||
|     ) -> Result<Option<Criteria<'a>>, ResponseError> { |     ) -> Result<Option<Criteria<'a>>, ResponseError> { | ||||||
|   | |||||||
| @@ -59,7 +59,7 @@ pub fn index_update_callback(index_uid: &str, data: &Data, status: ProcessedUpda | |||||||
|     if let Some(index) = data.db.open_index(&index_uid) { |     if let Some(index) = data.db.open_index(&index_uid) { | ||||||
|         let db = &data.db; |         let db = &data.db; | ||||||
|         let res = db.main_write::<_, _, ResponseError>(|mut writer| { |         let res = db.main_write::<_, _, ResponseError>(|mut writer| { | ||||||
|             if let Err(e) = data.compute_stats(&mut writer, &index_uid) { |             if let Err(e) = data.db.compute_stats(&mut writer, &index_uid) { | ||||||
|                 error!("Impossible to compute stats; {}", e) |                 error!("Impossible to compute stats; {}", e) | ||||||
|             } |             } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -50,7 +50,7 @@ async fn index_stats( | |||||||
|     let update_reader = data.db.update_read_txn()?; |     let update_reader = data.db.update_read_txn()?; | ||||||
|  |  | ||||||
|     let is_indexing = |     let is_indexing = | ||||||
|         data.is_indexing(&update_reader, &path.index_uid)? |         data.db.is_indexing(&update_reader, &path.index_uid)? | ||||||
|             .ok_or(Error::internal( |             .ok_or(Error::internal( | ||||||
|                 "Impossible to know if the database is indexing", |                 "Impossible to know if the database is indexing", | ||||||
|             ))?; |             ))?; | ||||||
| @@ -86,7 +86,7 @@ async fn get_stats(data: web::Data<Data>) -> Result<HttpResponse, ResponseError> | |||||||
|  |  | ||||||
|                 let fields_distribution = index.main.fields_distribution(&reader)?.unwrap_or_default(); |                 let fields_distribution = index.main.fields_distribution(&reader)?.unwrap_or_default(); | ||||||
|  |  | ||||||
|                 let is_indexing = data.is_indexing(&update_reader, &index_uid)?.ok_or( |                 let is_indexing = data.db.is_indexing(&update_reader, &index_uid)?.ok_or( | ||||||
|                     Error::internal("Impossible to know if the database is indexing"), |                     Error::internal("Impossible to know if the database is indexing"), | ||||||
|                 )?; |                 )?; | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user