mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 04:56:28 +00:00 
			
		
		
		
	Merge branch 'fix-3037' of github.com:jiangbo212/meilisearch into fix-3037
This commit is contained in:
		| @@ -13,7 +13,7 @@ use uuid::Uuid; | ||||
|  | ||||
| use self::IndexStatus::{Available, BeingDeleted}; | ||||
| use crate::uuid_codec::UuidCodec; | ||||
| use crate::{Error, Result}; | ||||
| use crate::{clamp_to_page_size, Error, Result}; | ||||
|  | ||||
| const INDEX_MAPPING: &str = "index-mapping"; | ||||
|  | ||||
| @@ -68,7 +68,7 @@ impl IndexMapper { | ||||
|     /// The path *must* exists or an error will be thrown. | ||||
|     fn create_or_open_index(&self, path: &Path) -> Result<Index> { | ||||
|         let mut options = EnvOpenOptions::new(); | ||||
|         options.map_size(self.index_size); | ||||
|         options.map_size(clamp_to_page_size(self.index_size)); | ||||
|         options.max_readers(1024); | ||||
|         Ok(Index::new(options, path)?) | ||||
|     } | ||||
|   | ||||
| @@ -55,7 +55,7 @@ use utils::{filter_out_references_to_newer_tasks, keep_tasks_within_datetimes, m | ||||
| use uuid::Uuid; | ||||
|  | ||||
| use crate::index_mapper::IndexMapper; | ||||
| use crate::utils::check_index_swap_validity; | ||||
| use crate::utils::{check_index_swap_validity, clamp_to_page_size}; | ||||
|  | ||||
| pub(crate) type BEI128 = | ||||
|     meilisearch_types::heed::zerocopy::I128<meilisearch_types::heed::byteorder::BE>; | ||||
| @@ -362,7 +362,7 @@ impl IndexScheduler { | ||||
|  | ||||
|         let env = heed::EnvOpenOptions::new() | ||||
|             .max_dbs(10) | ||||
|             .map_size(options.task_db_size) | ||||
|             .map_size(clamp_to_page_size(options.task_db_size)) | ||||
|             .open(options.tasks_path)?; | ||||
|         let file_store = FileStore::new(&options.update_file_path)?; | ||||
|  | ||||
| @@ -1114,8 +1114,8 @@ mod tests { | ||||
|                 indexes_path: tempdir.path().join("indexes"), | ||||
|                 snapshots_path: tempdir.path().join("snapshots"), | ||||
|                 dumps_path: tempdir.path().join("dumps"), | ||||
|                 task_db_size: 1024 * 1024, // 1 MiB | ||||
|                 index_size: 1024 * 1024,   // 1 MiB | ||||
|                 task_db_size: 1000 * 1000, // 1 MB, we don't use MiB on purpose. | ||||
|                 index_size: 1000 * 1000,   // 1 MB, we don't use MiB on purpose. | ||||
|                 indexer_config: IndexerConfig::default(), | ||||
|                 autobatching_enabled, | ||||
|             }; | ||||
|   | ||||
| @@ -324,6 +324,11 @@ pub(crate) fn check_index_swap_validity(task: &Task) -> Result<()> { | ||||
|     Ok(()) | ||||
| } | ||||
|  | ||||
| /// Clamp the provided value to be a multiple of system page size. | ||||
| pub fn clamp_to_page_size(size: usize) -> usize { | ||||
|     size / page_size::get() * page_size::get() | ||||
| } | ||||
|  | ||||
| #[cfg(test)] | ||||
| impl IndexScheduler { | ||||
|     /// Asserts that the index scheduler's content is internally consistent. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user