mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Merge #2192
2192: Fix max dbs error r=Kerollmops a=MarinPostma Factor the way we open environments to make sure they are always opened with the same options. The issue was that indexes were first opened in snapshots with incorrect options, and heed cache returned an environment with incorrect open options on subsequent index open. fix #2190 Co-authored-by: ad hoc <postma.marin@protonmail.com>
This commit is contained in:
		| @@ -17,6 +17,7 @@ use sha2::{Digest, Sha256}; | ||||
| pub use action::{actions, Action}; | ||||
| use error::{AuthControllerError, Result}; | ||||
| pub use key::Key; | ||||
| pub use store::open_auth_store_env; | ||||
| use store::HeedAuthStore; | ||||
|  | ||||
| #[derive(Clone)] | ||||
|   | ||||
| @@ -39,14 +39,18 @@ impl Drop for HeedAuthStore { | ||||
|     } | ||||
| } | ||||
|  | ||||
| pub fn open_auth_store_env(path: &Path) -> heed::Result<heed::Env> { | ||||
|     let mut options = EnvOpenOptions::new(); | ||||
|     options.map_size(AUTH_STORE_SIZE); // 1GB | ||||
|     options.max_dbs(2); | ||||
|     options.open(path) | ||||
| } | ||||
|  | ||||
| impl HeedAuthStore { | ||||
|     pub fn new(path: impl AsRef<Path>) -> Result<Self> { | ||||
|         let path = path.as_ref().join(AUTH_DB_PATH); | ||||
|         create_dir_all(&path)?; | ||||
|         let mut options = EnvOpenOptions::new(); | ||||
|         options.map_size(AUTH_STORE_SIZE); // 1GB | ||||
|         options.max_dbs(2); | ||||
|         let env = Arc::new(options.open(path)?); | ||||
|         let env = Arc::new(open_auth_store_env(path.as_ref())?); | ||||
|         let keys = env.create_database(Some(KEY_DB_NAME))?; | ||||
|         let action_keyid_index_expiration = | ||||
|             env.create_database(Some(KEY_ID_ACTION_INDEX_EXPIRATION_DB_NAME))?; | ||||
|   | ||||
| @@ -128,7 +128,6 @@ async fn get_stats( | ||||
|     meilisearch: GuardedData<ActionPolicy<{ actions::STATS_GET }>, MeiliSearch>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let search_rules = &meilisearch.filters().search_rules; | ||||
|  | ||||
|     let response = meilisearch.get_all_stats(search_rules).await?; | ||||
|  | ||||
|     debug!("returns: {:?}", response); | ||||
|   | ||||
| @@ -48,6 +48,13 @@ pub type Payload = Box< | ||||
|     dyn Stream<Item = std::result::Result<Bytes, PayloadError>> + Send + Sync + 'static + Unpin, | ||||
| >; | ||||
|  | ||||
| pub fn open_meta_env(path: &Path, size: usize) -> heed::Result<heed::Env> { | ||||
|     let mut options = heed::EnvOpenOptions::new(); | ||||
|     options.map_size(size); | ||||
|     options.max_dbs(20); | ||||
|     options.open(path) | ||||
| } | ||||
|  | ||||
| #[derive(Debug, Serialize, Deserialize, Clone)] | ||||
| #[serde(rename_all = "camelCase")] | ||||
| pub struct IndexMetadata { | ||||
| @@ -201,11 +208,7 @@ impl IndexControllerBuilder { | ||||
|  | ||||
|         std::fs::create_dir_all(db_path.as_ref())?; | ||||
|  | ||||
|         let mut options = heed::EnvOpenOptions::new(); | ||||
|         options.map_size(task_store_size); | ||||
|         options.max_dbs(20); | ||||
|  | ||||
|         let meta_env = Arc::new(options.open(&db_path)?); | ||||
|         let meta_env = Arc::new(open_meta_env(db_path.as_ref(), task_store_size)?); | ||||
|  | ||||
|         let update_file_store = UpdateFileStore::new(&db_path)?; | ||||
|         // Create or overwrite the version file for this DB | ||||
|   | ||||
| @@ -6,11 +6,13 @@ use std::time::Duration; | ||||
| use anyhow::bail; | ||||
| use fs_extra::dir::{self, CopyOptions}; | ||||
| use log::{info, trace}; | ||||
| use meilisearch_auth::open_auth_store_env; | ||||
| use tokio::sync::RwLock; | ||||
| use tokio::time::sleep; | ||||
| use walkdir::WalkDir; | ||||
|  | ||||
| use crate::compression::from_tar_gz; | ||||
| use crate::index_controller::open_meta_env; | ||||
| use crate::index_controller::versioning::VERSION_FILE_NAME; | ||||
| use crate::tasks::task::Job; | ||||
| use crate::tasks::Scheduler; | ||||
| @@ -39,7 +41,6 @@ impl SnapshotService { | ||||
|             }; | ||||
|             let job = Job::Snapshot(snapshot_job); | ||||
|             self.scheduler.write().await.schedule_job(job).await; | ||||
|  | ||||
|             sleep(self.snapshot_period).await; | ||||
|         } | ||||
|     } | ||||
| @@ -145,9 +146,7 @@ impl SnapshotJob { | ||||
|     } | ||||
|  | ||||
|     fn snapshot_meta_env(&self, path: &Path) -> anyhow::Result<()> { | ||||
|         let mut options = heed::EnvOpenOptions::new(); | ||||
|         options.map_size(self.meta_env_size); | ||||
|         let env = options.open(&self.src_path)?; | ||||
|         let env = open_meta_env(&self.src_path, self.meta_env_size)?; | ||||
|  | ||||
|         let dst = path.join("data.mdb"); | ||||
|         env.copy_to_path(dst, heed::CompactionOption::Enabled)?; | ||||
| @@ -183,9 +182,10 @@ impl SnapshotJob { | ||||
|  | ||||
|             let mut options = heed::EnvOpenOptions::new(); | ||||
|             options.map_size(self.index_size); | ||||
|             let env = options.open(entry.path())?; | ||||
|  | ||||
|             env.copy_to_path(dst, heed::CompactionOption::Enabled)?; | ||||
|             let index = milli::Index::new(options, entry.path())?; | ||||
|             index | ||||
|                 .env | ||||
|                 .copy_to_path(dst, heed::CompactionOption::Enabled)?; | ||||
|         } | ||||
|  | ||||
|         Ok(()) | ||||
| @@ -197,9 +197,7 @@ impl SnapshotJob { | ||||
|         std::fs::create_dir_all(&dst)?; | ||||
|         let dst = dst.join("data.mdb"); | ||||
|  | ||||
|         let mut options = heed::EnvOpenOptions::new(); | ||||
|         options.map_size(1_073_741_824); | ||||
|         let env = options.open(auth_path)?; | ||||
|         let env = open_auth_store_env(&auth_path)?; | ||||
|         env.copy_to_path(dst, heed::CompactionOption::Enabled)?; | ||||
|  | ||||
|         Ok(()) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user