mirror of
https://github.com/meilisearch/meilisearch.git
synced 2025-01-19 01:18:31 +08:00
remove heed from http dependencies
This commit is contained in:
parent
d69180ec67
commit
c771694623
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"),
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user