mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Disable the cache by default and make it experimental
This commit is contained in:
		| @@ -125,6 +125,10 @@ pub struct IndexSchedulerOptions { | ||||
|     pub instance_features: InstanceTogglableFeatures, | ||||
|     /// The experimental features enabled for this instance. | ||||
|     pub auto_upgrade: bool, | ||||
|     /// The maximal number of entries in the search query cache of an embedder. | ||||
|     /// | ||||
|     /// 0 disables the cache. | ||||
|     pub embedding_cache_cap: usize, | ||||
| } | ||||
|  | ||||
| /// Structure which holds meilisearch's indexes and schedules the tasks | ||||
| @@ -156,6 +160,11 @@ pub struct IndexScheduler { | ||||
|     /// The Authorization header to send to the webhook URL. | ||||
|     pub(crate) webhook_authorization_header: Option<String>, | ||||
|  | ||||
|     /// A map to retrieve the runtime representation of an embedder depending on its configuration. | ||||
|     /// | ||||
|     /// This map may return the same embedder object for two different indexes or embedder settings, | ||||
|     /// but it will only do this if the embedder configuration options are the same, leading | ||||
|     /// to the same embeddings for the same input text. | ||||
|     embedders: Arc<RwLock<HashMap<EmbedderOptions, Arc<Embedder>>>>, | ||||
|  | ||||
|     // ================= test | ||||
| @@ -818,7 +827,7 @@ impl IndexScheduler { | ||||
|  | ||||
|                     // add missing embedder | ||||
|                     let embedder = Arc::new( | ||||
|                         Embedder::new(embedder_options.clone()) | ||||
|                         Embedder::new(embedder_options.clone(), self.scheduler.embedding_cache_cap) | ||||
|                             .map_err(meilisearch_types::milli::vector::Error::from) | ||||
|                             .map_err(|err| { | ||||
|                                 Error::from_milli(err.into(), Some(index_uid.clone())) | ||||
|   | ||||
| @@ -76,6 +76,11 @@ pub struct Scheduler { | ||||
|  | ||||
|     /// The path to the version file of Meilisearch. | ||||
|     pub(crate) version_file_path: PathBuf, | ||||
|  | ||||
|     /// The maximal number of entries in the search query cache of an embedder. | ||||
|     /// | ||||
|     /// 0 disables the cache. | ||||
|     pub(crate) embedding_cache_cap: usize, | ||||
| } | ||||
|  | ||||
| impl Scheduler { | ||||
| @@ -90,6 +95,7 @@ impl Scheduler { | ||||
|             snapshots_path: self.snapshots_path.clone(), | ||||
|             auth_env: self.auth_env.clone(), | ||||
|             version_file_path: self.version_file_path.clone(), | ||||
|             embedding_cache_cap: self.embedding_cache_cap, | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -105,6 +111,7 @@ impl Scheduler { | ||||
|             snapshots_path: options.snapshots_path.clone(), | ||||
|             auth_env, | ||||
|             version_file_path: options.version_file_path.clone(), | ||||
|             embedding_cache_cap: options.embedding_cache_cap, | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -112,6 +112,7 @@ impl IndexScheduler { | ||||
|             batched_tasks_size_limit: u64::MAX, | ||||
|             instance_features: Default::default(), | ||||
|             auto_upgrade: true, // Don't cost much and will ensure the happy path works | ||||
|             embedding_cache_cap: 10, | ||||
|         }; | ||||
|         let version = configuration(&mut options).unwrap_or_else(|| { | ||||
|             ( | ||||
|   | ||||
		Reference in New Issue
	
	Block a user