mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Fix autobatching of documents and settings
This commit is contained in:
		| @@ -115,13 +115,6 @@ pub enum BatchKind { | |||||||
|         allow_index_creation: bool, |         allow_index_creation: bool, | ||||||
|         settings_ids: Vec<TaskId>, |         settings_ids: Vec<TaskId>, | ||||||
|     }, |     }, | ||||||
|     SettingsAndDocumentOperation { |  | ||||||
|         settings_ids: Vec<TaskId>, |  | ||||||
|         method: IndexDocumentsMethod, |  | ||||||
|         allow_index_creation: bool, |  | ||||||
|         primary_key: Option<String>, |  | ||||||
|         operation_ids: Vec<TaskId>, |  | ||||||
|     }, |  | ||||||
|     Settings { |     Settings { | ||||||
|         allow_index_creation: bool, |         allow_index_creation: bool, | ||||||
|         settings_ids: Vec<TaskId>, |         settings_ids: Vec<TaskId>, | ||||||
| @@ -146,7 +139,6 @@ impl BatchKind { | |||||||
|         match self { |         match self { | ||||||
|             BatchKind::DocumentOperation { allow_index_creation, .. } |             BatchKind::DocumentOperation { allow_index_creation, .. } | ||||||
|             | BatchKind::ClearAndSettings { allow_index_creation, .. } |             | BatchKind::ClearAndSettings { allow_index_creation, .. } | ||||||
|             | BatchKind::SettingsAndDocumentOperation { allow_index_creation, .. } |  | ||||||
|             | BatchKind::Settings { allow_index_creation, .. } => Some(*allow_index_creation), |             | BatchKind::Settings { allow_index_creation, .. } => Some(*allow_index_creation), | ||||||
|             _ => None, |             _ => None, | ||||||
|         } |         } | ||||||
| @@ -154,10 +146,7 @@ impl BatchKind { | |||||||
|  |  | ||||||
|     fn primary_key(&self) -> Option<Option<&str>> { |     fn primary_key(&self) -> Option<Option<&str>> { | ||||||
|         match self { |         match self { | ||||||
|             BatchKind::DocumentOperation { primary_key, .. } |             BatchKind::DocumentOperation { primary_key, .. } => Some(primary_key.as_deref()), | ||||||
|             | BatchKind::SettingsAndDocumentOperation { primary_key, .. } => { |  | ||||||
|                 Some(primary_key.as_deref()) |  | ||||||
|             } |  | ||||||
|             _ => None, |             _ => None, | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -275,8 +264,7 @@ impl BatchKind { | |||||||
|                 Break(BatchKind::IndexDeletion { ids }) |                 Break(BatchKind::IndexDeletion { ids }) | ||||||
|             } |             } | ||||||
|             ( |             ( | ||||||
|                 BatchKind::ClearAndSettings { settings_ids: mut ids, allow_index_creation: _, mut other } |                 BatchKind::ClearAndSettings { settings_ids: mut ids, allow_index_creation: _, mut other }, | ||||||
|                 | BatchKind::SettingsAndDocumentOperation { operation_ids: mut ids, method: _, allow_index_creation: _, primary_key: _, settings_ids: mut other }, |  | ||||||
|                 K::IndexDeletion, |                 K::IndexDeletion, | ||||||
|             ) => { |             ) => { | ||||||
|                 ids.push(id); |                 ids.push(id); | ||||||
| @@ -356,15 +344,9 @@ impl BatchKind { | |||||||
|             ) => Break(this), |             ) => Break(this), | ||||||
|  |  | ||||||
|             ( |             ( | ||||||
|                 BatchKind::DocumentOperation { method, allow_index_creation, primary_key, operation_ids }, |                 this @ BatchKind::DocumentOperation { .. }, | ||||||
|                 K::Settings { .. }, |                 K::Settings { .. }, | ||||||
|             ) => Continue(BatchKind::SettingsAndDocumentOperation { |             ) => Break(this), | ||||||
|                 settings_ids: vec![id], |  | ||||||
|                 method, |  | ||||||
|                 allow_index_creation, |  | ||||||
|                 primary_key, |  | ||||||
|                 operation_ids, |  | ||||||
|             }), |  | ||||||
|  |  | ||||||
|             (BatchKind::DocumentDeletion { mut deletion_ids, includes_by_filter: _ }, K::DocumentClear) => { |             (BatchKind::DocumentDeletion { mut deletion_ids, includes_by_filter: _ }, K::DocumentClear) => { | ||||||
|                 deletion_ids.push(id); |                 deletion_ids.push(id); | ||||||
| @@ -477,63 +459,7 @@ impl BatchKind { | |||||||
|                     allow_index_creation, |                     allow_index_creation, | ||||||
|                 }) |                 }) | ||||||
|             } |             } | ||||||
|             ( |  | ||||||
|                 BatchKind::SettingsAndDocumentOperation { settings_ids, method: _, mut operation_ids, allow_index_creation, primary_key: _ }, |  | ||||||
|                 K::DocumentClear, |  | ||||||
|             ) => { |  | ||||||
|                 operation_ids.push(id); |  | ||||||
|                 Continue(BatchKind::ClearAndSettings { |  | ||||||
|                     settings_ids, |  | ||||||
|                     other: operation_ids, |  | ||||||
|                     allow_index_creation, |  | ||||||
|                 }) |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             ( |  | ||||||
|                 BatchKind::SettingsAndDocumentOperation { settings_ids, method: ReplaceDocuments, mut operation_ids, allow_index_creation, primary_key: _}, |  | ||||||
|                 K::DocumentImport { method: ReplaceDocuments, primary_key: pk2, .. }, |  | ||||||
|             ) => { |  | ||||||
|                 operation_ids.push(id); |  | ||||||
|                 Continue(BatchKind::SettingsAndDocumentOperation { |  | ||||||
|                     settings_ids, |  | ||||||
|                     method: ReplaceDocuments, |  | ||||||
|                     allow_index_creation, |  | ||||||
|                         primary_key: pk2, |  | ||||||
|                     operation_ids, |  | ||||||
|                 }) |  | ||||||
|             } |  | ||||||
|             ( |  | ||||||
|                 BatchKind::SettingsAndDocumentOperation { settings_ids, method: UpdateDocuments, allow_index_creation, primary_key: _, mut operation_ids }, |  | ||||||
|                 K::DocumentImport { method: UpdateDocuments, primary_key: pk2, .. }, |  | ||||||
|             ) => { |  | ||||||
|                 operation_ids.push(id); |  | ||||||
|                 Continue(BatchKind::SettingsAndDocumentOperation { |  | ||||||
|                     settings_ids, |  | ||||||
|                     method: UpdateDocuments, |  | ||||||
|                     allow_index_creation, |  | ||||||
|                     primary_key: pk2, |  | ||||||
|                     operation_ids, |  | ||||||
|                 }) |  | ||||||
|             } |  | ||||||
|             // But we can't batch a settings and a doc op with another doc op |  | ||||||
|             // this MUST be AFTER the two previous branch |  | ||||||
|             ( |  | ||||||
|                 this @ BatchKind::SettingsAndDocumentOperation { .. }, |  | ||||||
|                 K::DocumentDeletion { .. } | K::DocumentImport { .. }, |  | ||||||
|             ) => Break(this), |  | ||||||
|             ( |  | ||||||
|                 BatchKind::SettingsAndDocumentOperation { mut settings_ids, method, allow_index_creation,primary_key, operation_ids }, |  | ||||||
|                 K::Settings { .. }, |  | ||||||
|             ) => { |  | ||||||
|                 settings_ids.push(id); |  | ||||||
|                 Continue(BatchKind::SettingsAndDocumentOperation { |  | ||||||
|                     settings_ids, |  | ||||||
|                     method, |  | ||||||
|                     allow_index_creation, |  | ||||||
|                     primary_key, |  | ||||||
|                     operation_ids, |  | ||||||
|                 }) |  | ||||||
|             } |  | ||||||
|             ( |             ( | ||||||
|                 BatchKind::IndexCreation { .. } |                 BatchKind::IndexCreation { .. } | ||||||
|                 | BatchKind::IndexDeletion { .. } |                 | BatchKind::IndexDeletion { .. } | ||||||
|   | |||||||
| @@ -441,67 +441,6 @@ impl IndexScheduler { | |||||||
|                     must_create_index, |                     must_create_index, | ||||||
|                 })) |                 })) | ||||||
|             } |             } | ||||||
|             BatchKind::SettingsAndDocumentOperation { |  | ||||||
|                 settings_ids, |  | ||||||
|                 method, |  | ||||||
|                 allow_index_creation, |  | ||||||
|                 primary_key, |  | ||||||
|                 operation_ids, |  | ||||||
|             } => { |  | ||||||
|                 let settings = self.create_next_batch_index( |  | ||||||
|                     rtxn, |  | ||||||
|                     index_uid.clone(), |  | ||||||
|                     BatchKind::Settings { settings_ids, allow_index_creation }, |  | ||||||
|                     current_batch, |  | ||||||
|                     must_create_index, |  | ||||||
|                 )?; |  | ||||||
|  |  | ||||||
|                 let document_import = self.create_next_batch_index( |  | ||||||
|                     rtxn, |  | ||||||
|                     index_uid.clone(), |  | ||||||
|                     BatchKind::DocumentOperation { |  | ||||||
|                         method, |  | ||||||
|                         allow_index_creation, |  | ||||||
|                         primary_key, |  | ||||||
|                         operation_ids, |  | ||||||
|                     }, |  | ||||||
|                     current_batch, |  | ||||||
|                     must_create_index, |  | ||||||
|                 )?; |  | ||||||
|  |  | ||||||
|                 match (document_import, settings) { |  | ||||||
|                     ( |  | ||||||
|                         Some(Batch::IndexOperation { |  | ||||||
|                             op: |  | ||||||
|                                 IndexOperation::DocumentOperation { |  | ||||||
|                                     primary_key, |  | ||||||
|                                     documents_counts, |  | ||||||
|                                     operations, |  | ||||||
|                                     tasks: document_import_tasks, |  | ||||||
|                                     .. |  | ||||||
|                                 }, |  | ||||||
|                             .. |  | ||||||
|                         }), |  | ||||||
|                         Some(Batch::IndexOperation { |  | ||||||
|                             op: IndexOperation::Settings { settings, tasks: settings_tasks, .. }, |  | ||||||
|                             .. |  | ||||||
|                         }), |  | ||||||
|                     ) => Ok(Some(Batch::IndexOperation { |  | ||||||
|                         op: IndexOperation::SettingsAndDocumentOperation { |  | ||||||
|                             index_uid, |  | ||||||
|                             primary_key, |  | ||||||
|                             method, |  | ||||||
|                             documents_counts, |  | ||||||
|                             operations, |  | ||||||
|                             document_import_tasks, |  | ||||||
|                             settings, |  | ||||||
|                             settings_tasks, |  | ||||||
|                         }, |  | ||||||
|                         must_create_index, |  | ||||||
|                     })), |  | ||||||
|                     _ => unreachable!(), |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             BatchKind::IndexCreation { id } => { |             BatchKind::IndexCreation { id } => { | ||||||
|                 let mut task = self.get_task(rtxn, id)?.ok_or(Error::CorruptedTaskQueue)?; |                 let mut task = self.get_task(rtxn, id)?.ok_or(Error::CorruptedTaskQueue)?; | ||||||
|                 current_batch.processing(Some(&mut task)); |                 current_batch.processing(Some(&mut task)); | ||||||
|   | |||||||
| @@ -106,7 +106,7 @@ impl ProcessingBatch { | |||||||
|         self.stats.total_nb_tasks = 0; |         self.stats.total_nb_tasks = 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /// Update the timestamp of the tasks and the inner structure of this sturcture. |     /// Update the timestamp of the tasks and the inner structure of this structure. | ||||||
|     pub fn update(&mut self, task: &mut Task) { |     pub fn update(&mut self, task: &mut Task) { | ||||||
|         // We must re-set this value in case we're dealing with a task that has been added between |         // We must re-set this value in case we're dealing with a task that has been added between | ||||||
|         // the `processing` and `finished` state |         // the `processing` and `finished` state | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user