mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	improve the way we access the mutex
This commit is contained in:
		| @@ -230,7 +230,7 @@ impl ErrorCode for Error { | ||||
|             Error::InvalidTaskCanceledBy { .. } => Code::InvalidTaskCanceledBy, | ||||
|             Error::InvalidIndexUid { .. } => Code::InvalidIndexUid, | ||||
|             Error::TaskNotFound(_) => Code::TaskNotFound, | ||||
|             Error::BatchNotFound(_) => Code::TaskNotFound, | ||||
|             Error::BatchNotFound(_) => Code::BatchNotFound, | ||||
|             Error::TaskDeletionWithEmptyQuery => Code::MissingTaskFilters, | ||||
|             Error::TaskCancelationWithEmptyQuery => Code::MissingTaskFilters, | ||||
|             // TODO: not sure of the Code to use | ||||
|   | ||||
| @@ -163,7 +163,7 @@ impl Query { | ||||
| } | ||||
|  | ||||
| #[derive(Debug, Clone)] | ||||
| struct ProcessingTasks { | ||||
| pub struct ProcessingTasks { | ||||
|     batch: Option<ProcessingBatch>, | ||||
|     /// The list of tasks ids that are currently running. | ||||
|     processing: RoaringBitmap, | ||||
| @@ -948,6 +948,7 @@ impl IndexScheduler { | ||||
|         processing: &ProcessingTasks, | ||||
|         query: &Query, | ||||
|     ) -> Result<RoaringBitmap> { | ||||
|         dbg!(); | ||||
|         let mut batches = self.all_batch_ids(rtxn)?; | ||||
|         if let Some(batch_id) = processing.batch.as_ref().map(|batch| batch.uid) { | ||||
|             batches.insert(batch_id); | ||||
| @@ -1235,22 +1236,21 @@ impl IndexScheduler { | ||||
|     /// 1. IndexSwap tasks are not publicly associated with any index, but they are associated | ||||
|     /// with many indexes internally. | ||||
|     /// 2. The user may not have the rights to access the tasks (internally) associated with all indexes. | ||||
|     pub fn get_batch_ids_from_authorized_indexes( | ||||
|     fn get_batch_ids_from_authorized_indexes( | ||||
|         &self, | ||||
|         rtxn: &RoTxn, | ||||
|         processing: &ProcessingTasks, | ||||
|         query: &Query, | ||||
|         filters: &meilisearch_auth::AuthFilter, | ||||
|     ) -> Result<(RoaringBitmap, u64)> { | ||||
|         let processing = self.processing_tasks.read().unwrap().clone(); | ||||
|  | ||||
|         // compute all batches matching the filter by ignoring the limits, to find the number of batches matching | ||||
|         // the filter. | ||||
|         // As this causes us to compute the filter twice it is slightly inefficient, but doing it this way spares | ||||
|         // us from modifying the underlying implementation, and the performance remains sufficient. | ||||
|         // Should this change, we would modify `get_batch_ids` to directly return the number of matching batches. | ||||
|         let total_batches = | ||||
|             self.get_batch_ids(rtxn, &processing, &query.clone().without_limits())?; | ||||
|         let mut batches = self.get_batch_ids(rtxn, &processing, query)?; | ||||
|             self.get_batch_ids(rtxn, processing, &query.clone().without_limits())?; | ||||
|         let mut batches = self.get_batch_ids(rtxn, processing, query)?; | ||||
|  | ||||
|         // If the query contains a list of index uid or there is a finite list of authorized indexes, | ||||
|         // then we must exclude all the batches that only contains tasks associated to multiple indexes. | ||||
| @@ -1369,11 +1369,14 @@ impl IndexScheduler { | ||||
|         filters: &meilisearch_auth::AuthFilter, | ||||
|     ) -> Result<(Vec<Batch>, u64)> { | ||||
|         let rtxn = self.env.read_txn()?; | ||||
|         let processing = self.processing_tasks.read().unwrap().clone(); | ||||
|  | ||||
|         let (batches, total) = | ||||
|             self.get_batch_ids_from_authorized_indexes(&rtxn, &query, filters)?; | ||||
|             self.get_batch_ids_from_authorized_indexes(&rtxn, &processing, &query, filters)?; | ||||
|  | ||||
|         let batches = self.get_existing_batches( | ||||
|             &rtxn, | ||||
|             &processing, | ||||
|             batches.into_iter().rev().take(query.limit.unwrap_or(u32::MAX) as usize), | ||||
|         )?; | ||||
|  | ||||
| @@ -4202,46 +4205,47 @@ mod tests { | ||||
|         handle.advance_n_successful_batches(3); | ||||
|         snapshot!(snapshot_index_scheduler(&index_scheduler), name: "processed_all_tasks"); | ||||
|  | ||||
|         let proc = index_scheduler.processing_tasks.read().unwrap().clone(); | ||||
|         let rtxn = index_scheduler.env.read_txn().unwrap(); | ||||
|         let query = Query { limit: Some(0), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[]"); | ||||
|  | ||||
|         let query = Query { limit: Some(1), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[2,]"); | ||||
|  | ||||
|         let query = Query { limit: Some(2), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[1,2,]"); | ||||
|  | ||||
|         let query = Query { from: Some(1), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[0,1,]"); | ||||
|  | ||||
|         let query = Query { from: Some(2), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[0,1,2,]"); | ||||
|  | ||||
|         let query = Query { from: Some(1), limit: Some(1), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[1,]"); | ||||
|  | ||||
|         let query = Query { from: Some(1), limit: Some(2), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[0,1,]"); | ||||
|     } | ||||
| @@ -4265,16 +4269,17 @@ mod tests { | ||||
|         handle.advance_till([Start, BatchCreated]); | ||||
|  | ||||
|         let rtxn = index_scheduler.env.read_txn().unwrap(); | ||||
|         let proc = index_scheduler.processing_tasks.read().unwrap().clone(); | ||||
|  | ||||
|         let query = Query { statuses: Some(vec![Status::Processing]), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[0,]"); // only the processing batch in the first tick | ||||
|  | ||||
|         let query = Query { statuses: Some(vec![Status::Enqueued]), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[]"); // The batches don't contains any enqueued tasks | ||||
|  | ||||
| @@ -4283,7 +4288,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[0,]"); // both enqueued and processing tasks in the first tick | ||||
|  | ||||
| @@ -4293,7 +4298,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // both enqueued and processing tasks in the first tick, but limited to those with a started_at | ||||
|         // that comes after the start of the test, which should excludes the enqueued tasks | ||||
| @@ -4305,7 +4310,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // both enqueued and processing tasks in the first tick, but limited to those with a started_at | ||||
|         // that comes before the start of the test, which should excludes all of them | ||||
| @@ -4318,7 +4323,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // both enqueued and processing tasks in the first tick, but limited to those with a started_at | ||||
|         // that comes after the start of the test and before one minute after the start of the test, | ||||
| @@ -4333,8 +4338,10 @@ mod tests { | ||||
|             Start, | ||||
|             BatchCreated, | ||||
|         ]); | ||||
|         snapshot!(snapshot_index_scheduler(&index_scheduler), name: "after-advancing-a-bit"); | ||||
|  | ||||
|         let rtxn = index_scheduler.env.read_txn().unwrap(); | ||||
|         let proc = index_scheduler.processing_tasks.read().unwrap().clone(); | ||||
|  | ||||
|         let second_start_time = OffsetDateTime::now_utc(); | ||||
|  | ||||
| @@ -4345,7 +4352,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // both succeeded and processing tasks in the first tick, but limited to those with a started_at | ||||
|         // that comes after the start of the test and before one minute after the start of the test, | ||||
| @@ -4358,7 +4365,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // both succeeded and processing tasks in the first tick, but limited to those with a started_at | ||||
|         // that comes before the start of the test, which should exclude all tasks | ||||
| @@ -4371,7 +4378,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // both succeeded and processing tasks in the first tick, but limited to those with a started_at | ||||
|         // that comes after the start of the second part of the test and before one minute after the | ||||
| @@ -4389,9 +4396,10 @@ mod tests { | ||||
|         ]); | ||||
|  | ||||
|         let rtxn = index_scheduler.env.read_txn().unwrap(); | ||||
|         let proc = index_scheduler.processing_tasks.read().unwrap().clone(); | ||||
|  | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // we run the same query to verify that, and indeed find that the last task is matched | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[2,]"); | ||||
| @@ -4403,7 +4411,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // enqueued, succeeded, or processing tasks started after the second part of the test, should | ||||
|         // again only return the last task | ||||
| @@ -4411,11 +4419,12 @@ mod tests { | ||||
|  | ||||
|         handle.advance_till([ProcessBatchFailed, AfterProcessing]); | ||||
|         let rtxn = index_scheduler.read_txn().unwrap(); | ||||
|         let proc = index_scheduler.processing_tasks.read().unwrap().clone(); | ||||
|  | ||||
|         // now the last task should have failed | ||||
|         snapshot!(snapshot_index_scheduler(&index_scheduler), name: "end"); | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // so running the last query should return nothing | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[]"); | ||||
| @@ -4427,7 +4436,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // but the same query on failed tasks should return the last task | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[2,]"); | ||||
| @@ -4439,7 +4448,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // but the same query on failed tasks should return the last task | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[2,]"); | ||||
| @@ -4452,7 +4461,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // same query but with an invalid uid | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[]"); | ||||
| @@ -4465,7 +4474,7 @@ mod tests { | ||||
|             ..Default::default() | ||||
|         }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // same query but with a valid uid | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[2,]"); | ||||
| @@ -4494,10 +4503,11 @@ mod tests { | ||||
|         handle.advance_till([Start, BatchCreated]); | ||||
|  | ||||
|         let rtxn = index_scheduler.env.read_txn().unwrap(); | ||||
|         let proc = index_scheduler.processing_tasks.read().unwrap().clone(); | ||||
|  | ||||
|         let query = Query { index_uids: Some(vec!["catto".to_owned()]), ..Default::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // only the first task associated with catto is returned, the indexSwap tasks are excluded! | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[0,]"); | ||||
| @@ -4506,6 +4516,7 @@ mod tests { | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes( | ||||
|                 &rtxn, | ||||
|                 &proc, | ||||
|                 &query, | ||||
|                 &AuthFilter::with_allowed_indexes( | ||||
|                     vec![IndexUidPattern::new_unchecked("doggo")].into_iter().collect(), | ||||
| @@ -4533,6 +4544,7 @@ mod tests { | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes( | ||||
|                 &rtxn, | ||||
|                 &proc, | ||||
|                 &query, | ||||
|                 &AuthFilter::with_allowed_indexes( | ||||
|                     vec![IndexUidPattern::new_unchecked("doggo")].into_iter().collect(), | ||||
| @@ -4547,6 +4559,7 @@ mod tests { | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes( | ||||
|                 &rtxn, | ||||
|                 &proc, | ||||
|                 &query, | ||||
|                 &AuthFilter::with_allowed_indexes( | ||||
|                     vec![ | ||||
| @@ -4564,7 +4577,7 @@ mod tests { | ||||
|  | ||||
|         let query = Query::default(); | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // we asked for all the tasks with all index authorized -> all tasks returned | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[0,1,2,3,]"); | ||||
| @@ -4595,9 +4608,10 @@ mod tests { | ||||
|         snapshot!(snapshot_index_scheduler(&index_scheduler), name: "start"); | ||||
|  | ||||
|         let rtxn = index_scheduler.read_txn().unwrap(); | ||||
|         let proc = index_scheduler.processing_tasks.read().unwrap().clone(); | ||||
|         let query = Query { canceled_by: Some(vec![task_cancelation.uid]), ..Query::default() }; | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &query, &AuthFilter::default()) | ||||
|             .get_batch_ids_from_authorized_indexes(&rtxn, &proc, &query, &AuthFilter::default()) | ||||
|             .unwrap(); | ||||
|         // The batch zero was the index creation task, the 1 is the task cancellation | ||||
|         snapshot!(snapshot_bitmap(&batches), @"[1,]"); | ||||
| @@ -4606,6 +4620,7 @@ mod tests { | ||||
|         let (batches, _) = index_scheduler | ||||
|             .get_batch_ids_from_authorized_indexes( | ||||
|                 &rtxn, | ||||
|                 &proc, | ||||
|                 &query, | ||||
|                 &AuthFilter::with_allowed_indexes( | ||||
|                     vec![IndexUidPattern::new_unchecked("doggo")].into_iter().collect(), | ||||
|   | ||||
| @@ -38,7 +38,7 @@ doggos [0,1,] | ||||
| [timestamp] [0,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentDeletion":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"providedIds":2,"deletedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentDeletion":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -42,7 +42,7 @@ doggos: { number_of_documents: 3, field_distribution: {"catto": 1, "doggo": 2, " | ||||
| [timestamp] [1,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentDeletion":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"providedIds":2,"deletedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentDeletion":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":3,"indexedDocuments":3}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
|   | ||||
| @@ -35,7 +35,7 @@ doggos [0,] | ||||
| [timestamp] [0,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -55,7 +55,7 @@ doggos: { number_of_documents: 1, field_distribution: {"doggo": 1, "id": 1} } | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"filterableAttributes":["catto"]}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"settingsUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":3,"indexedDocuments":3}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"providedIds":1,"deletedDocuments":2,"originalFilter":"\"catto EXISTS\""}, stats: {"totalNbTasks":4,"status":{"succeeded":2,"failed":2},"types":{"documentDeletion":4},"indexUids":{"doggos":4}}, } | ||||
| 2 {uid: 2, details: {"providedIds":1,"deletedDocuments":2,"originalFilter":"true&\"id = 2\"&\"catto EXISTS\""}, stats: {"totalNbTasks":4,"status":{"succeeded":2,"failed":2},"types":{"documentDeletion":4},"indexUids":{"doggos":4}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -35,7 +35,7 @@ catto [0,] | ||||
| [timestamp] [0,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexCreation":1},"indexUids":{"catto":1}}, } | ||||
| 0 {uid: 0, details: {"primaryKey":"mouse"}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexCreation":1},"indexUids":{"catto":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -35,7 +35,7 @@ catto [0,] | ||||
| [timestamp] [0,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexCreation":1},"indexUids":{"catto":1}}, } | ||||
| 0 {uid: 0, details: {"primaryKey":"mouse"}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexCreation":1},"indexUids":{"catto":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -50,7 +50,7 @@ doggo: { number_of_documents: 0, field_distribution: {} } | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"primaryKey":"mouse"}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"indexCreation":1},"indexUids":{"catto":1}}, } | ||||
| 1 {uid: 1, details: {"primaryKey":"sheep"}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"indexCreation":1},"indexUids":{"doggo":1}}, } | ||||
| 2 {uid: 2, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexCreation":1},"indexUids":{"whalo":1}}, } | ||||
| 2 {uid: 2, details: {"primaryKey":"fish"}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexCreation":1},"indexUids":{"whalo":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -55,8 +55,8 @@ doggo: { number_of_documents: 0, field_distribution: {} } | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"primaryKey":"mouse"}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"indexCreation":1},"indexUids":{"catto":1}}, } | ||||
| 1 {uid: 1, details: {"primaryKey":"sheep"}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"indexCreation":1},"indexUids":{"doggo":1}}, } | ||||
| 2 {uid: 2, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexSwap":1},"indexUids":{}}, } | ||||
| 3 {uid: 3, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexSwap":1},"indexUids":{}}, } | ||||
| 2 {uid: 2, details: {"swaps":[{"indexes":["catto","doggo"]}]}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexSwap":1},"indexUids":{}}, } | ||||
| 3 {uid: 3, details: {"swaps":[{"indexes":["catto","whalo"]}]}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexSwap":1},"indexUids":{}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -50,7 +50,7 @@ doggo: { number_of_documents: 0, field_distribution: {} } | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"primaryKey":"mouse"}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"indexCreation":1},"indexUids":{"catto":1}}, } | ||||
| 1 {uid: 1, details: {"primaryKey":"sheep"}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"indexCreation":1},"indexUids":{"doggo":1}}, } | ||||
| 2 {uid: 2, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexCreation":1},"indexUids":{"whalo":1}}, } | ||||
| 2 {uid: 2, details: {"primaryKey":"fish"}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexCreation":1},"indexUids":{"whalo":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -66,7 +66,7 @@ d: { number_of_documents: 0, field_distribution: {} } | ||||
| 1 {uid: 1, details: {"primaryKey":"id"}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"indexCreation":1},"indexUids":{"b":1}}, } | ||||
| 2 {uid: 2, details: {"primaryKey":"id"}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"indexCreation":1},"indexUids":{"c":1}}, } | ||||
| 3 {uid: 3, details: {"primaryKey":"id"}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"indexCreation":1},"indexUids":{"d":1}}, } | ||||
| 4 {uid: 4, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexSwap":1},"indexUids":{}}, } | ||||
| 4 {uid: 4, details: {"swaps":[{"indexes":["a","b"]},{"indexes":["c","e"]},{"indexes":["d","f"]}]}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"indexSwap":1},"indexUids":{}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -53,7 +53,7 @@ doggos [0,1,2,3,4,5,6,7,8,9,] | ||||
| [timestamp] [0,1,2,3,4,5,6,7,8,9,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":10,"status":{"failed":10},"types":{"documentAdditionOrUpdate":10},"indexUids":{"doggos":10}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":10,"indexedDocuments":0}, stats: {"totalNbTasks":10,"status":{"failed":10},"types":{"documentAdditionOrUpdate":10},"indexUids":{"doggos":10}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,1,2,3,4,5,6,7,8,9,] | ||||
|   | ||||
| @@ -71,16 +71,16 @@ doggos [0,1,2,3,4,5,6,7,8,9,] | ||||
| [timestamp] [9,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 3 {uid: 3, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 4 {uid: 4, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 5 {uid: 5, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 6 {uid: 6, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 7 {uid: 7, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 8 {uid: 8, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 9 {uid: 9, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 3 {uid: 3, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 4 {uid: 4, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 5 {uid: 5, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 6 {uid: 6, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 7 {uid: 7, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 8 {uid: 8, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 9 {uid: 9, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -61,11 +61,11 @@ doggos [0,1,2,3,4,5,6,7,8,9,] | ||||
| [timestamp] [4,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 3 {uid: 3, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 4 {uid: 4, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 3 {uid: 3, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 4 {uid: 4, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -57,7 +57,7 @@ doggos: { number_of_documents: 9, field_distribution: {"doggo": 9, "id": 9} } | ||||
| [timestamp] [1,2,3,4,5,6,7,8,9,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":9,"indexedDocuments":9}, stats: {"totalNbTasks":9,"status":{"succeeded":9},"types":{"documentAdditionOrUpdate":9},"indexUids":{"doggos":9}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
|   | ||||
| @@ -53,7 +53,7 @@ doggos [0,1,2,3,4,5,6,7,8,9,] | ||||
| [timestamp] [0,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -51,9 +51,9 @@ doggos: { number_of_documents: 2, field_distribution: {"doggo": 2, "id": 2} } | ||||
| [timestamp] [4,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":2,"status":{"failed":2},"types":{"documentAdditionOrUpdate":2},"indexUids":{"doggos":2}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":2,"indexedDocuments":0}, stats: {"totalNbTasks":2,"status":{"failed":2},"types":{"documentAdditionOrUpdate":2},"indexUids":{"doggos":2}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 3 {uid: 3, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
|   | ||||
| @@ -44,7 +44,7 @@ doggos: { number_of_documents: 0, field_distribution: {} } | ||||
| [timestamp] [0,1,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":2,"status":{"failed":2},"types":{"documentAdditionOrUpdate":2},"indexUids":{"doggos":2}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":2,"indexedDocuments":0}, stats: {"totalNbTasks":2,"status":{"failed":2},"types":{"documentAdditionOrUpdate":2},"indexUids":{"doggos":2}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,1,] | ||||
|   | ||||
| @@ -49,9 +49,9 @@ doggos: { number_of_documents: 1, field_distribution: {"doggo": 1, "id": 1} } | ||||
| [timestamp] [3,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":2,"status":{"failed":2},"types":{"documentAdditionOrUpdate":2},"indexUids":{"doggos":2}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":2,"indexedDocuments":0}, stats: {"totalNbTasks":2,"status":{"failed":2},"types":{"documentAdditionOrUpdate":2},"indexUids":{"doggos":2}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,1,] | ||||
|   | ||||
| @@ -47,7 +47,7 @@ doggos: { number_of_documents: 1, field_distribution: {"doggo": 1, "id": 1} } | ||||
| [timestamp] [2,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":2,"status":{"failed":2},"types":{"documentAdditionOrUpdate":2},"indexUids":{"doggos":2}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":2,"indexedDocuments":0}, stats: {"totalNbTasks":2,"status":{"failed":2},"types":{"documentAdditionOrUpdate":2},"indexUids":{"doggos":2}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
|   | ||||
| @@ -44,7 +44,7 @@ doggos: { number_of_documents: 1, field_distribution: {"doggo": 1, "id": 1} } | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -46,8 +46,8 @@ doggos: { number_of_documents: 1, field_distribution: {"doggo": 1, "id": 1} } | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -44,7 +44,7 @@ doggos: { number_of_documents: 1, field_distribution: {"doggo": 1, "id": 1} } | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -53,8 +53,8 @@ doggos: { number_of_documents: 4, field_distribution: {"doggo": 4, "paw": 4} } | ||||
| [timestamp] [3,4,5,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 3 {uid: 3, details: {"receivedDocuments":3,"indexedDocuments":3}, stats: {"totalNbTasks":3,"status":{"succeeded":3},"types":{"documentAdditionOrUpdate":3},"indexUids":{"doggos":3}}, } | ||||
| ---------------------------------------------------------------------- | ||||
|   | ||||
| @@ -46,7 +46,7 @@ doggos: { number_of_documents: 0, field_distribution: {} } | ||||
| [timestamp] [0,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -48,8 +48,8 @@ doggos: { number_of_documents: 0, field_distribution: {} } | ||||
| [timestamp] [1,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -51,8 +51,8 @@ doggos: { number_of_documents: 1, field_distribution: {"doggo": 1, "paw": 1} } | ||||
| [timestamp] [2,] | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
|   | ||||
| @@ -54,7 +54,7 @@ doggos: { number_of_documents: 5, field_distribution: {"doggo": 5, "doggoid": 5} | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 3 {uid: 3, details: {"receivedDocuments":3,"indexedDocuments":3}, stats: {"totalNbTasks":3,"status":{"succeeded":3},"types":{"documentAdditionOrUpdate":3},"indexUids":{"doggos":3}}, } | ||||
| ---------------------------------------------------------------------- | ||||
|   | ||||
| @@ -50,7 +50,7 @@ doggos: { number_of_documents: 1, field_distribution: {"doggo": 1, "doggoid": 1} | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
| 0 [0,] | ||||
|   | ||||
| @@ -52,7 +52,7 @@ doggos: { number_of_documents: 2, field_distribution: {"doggo": 2, "doggoid": 2} | ||||
| ---------------------------------------------------------------------- | ||||
| ### All Batches: | ||||
| 0 {uid: 0, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 1 {uid: 1, details: {"receivedDocuments":1,"indexedDocuments":0}, stats: {"totalNbTasks":1,"status":{"failed":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| 2 {uid: 2, details: {"receivedDocuments":1,"indexedDocuments":1}, stats: {"totalNbTasks":1,"status":{"succeeded":1},"types":{"documentAdditionOrUpdate":1},"indexUids":{"doggos":1}}, } | ||||
| ---------------------------------------------------------------------- | ||||
| ### Batch to tasks mapping: | ||||
|   | ||||
| @@ -12,7 +12,7 @@ use meilisearch_types::tasks::{Details, IndexSwap, Kind, KindWithContent, Status | ||||
| use roaring::{MultiOps, RoaringBitmap}; | ||||
| use time::OffsetDateTime; | ||||
|  | ||||
| use crate::{Error, IndexScheduler, Result, Task, TaskId, BEI128}; | ||||
| use crate::{Error, IndexScheduler, ProcessingTasks, Result, Task, TaskId, BEI128}; | ||||
|  | ||||
| /// This structure contains all the information required to write a batch in the database without reading the tasks. | ||||
| /// It'll stay in RAM so it must be small. | ||||
| @@ -106,10 +106,8 @@ impl ProcessingBatch { | ||||
|         self.statuses.insert(task.status); | ||||
|  | ||||
|         // Craft an aggregation of the details of all the tasks encountered in this batch. | ||||
|         if task.status != Status::Failed { | ||||
|             if let Some(ref details) = task.details { | ||||
|                 self.details.accumulate(&DetailsView::from(details.clone())); | ||||
|             } | ||||
|         if let Some(ref details) = task.details { | ||||
|             self.details.accumulate(&DetailsView::from(details.clone())); | ||||
|         } | ||||
|         self.stats.total_nb_tasks += 1; | ||||
|         *self.stats.status.entry(task.status).or_default() += 1; | ||||
| @@ -118,6 +116,16 @@ impl ProcessingBatch { | ||||
|             *self.stats.index_uids.entry(index_uid.to_string()).or_default() += 1; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     pub fn to_batch(&self) -> Batch { | ||||
|         Batch { | ||||
|             uid: self.uid, | ||||
|             details: self.details.clone(), | ||||
|             stats: self.stats.clone(), | ||||
|             started_at: self.started_at, | ||||
|             finished_at: self.finished_at, | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| impl IndexScheduler { | ||||
| @@ -243,13 +251,18 @@ impl IndexScheduler { | ||||
|     pub(crate) fn get_existing_batches( | ||||
|         &self, | ||||
|         rtxn: &RoTxn, | ||||
|         processing: &ProcessingTasks, | ||||
|         tasks: impl IntoIterator<Item = BatchId>, | ||||
|     ) -> Result<Vec<Batch>> { | ||||
|         tasks | ||||
|             .into_iter() | ||||
|             .map(|batch_id| { | ||||
|                 self.get_batch(rtxn, batch_id) | ||||
|                     .and_then(|task| task.ok_or(Error::CorruptedTaskQueue)) | ||||
|                 if Some(batch_id) == processing.batch.as_ref().map(|batch| batch.uid) { | ||||
|                     Ok(processing.batch.as_ref().unwrap().to_batch()) | ||||
|                 } else { | ||||
|                     self.get_batch(rtxn, batch_id) | ||||
|                         .and_then(|task| task.ok_or(Error::CorruptedTaskQueue)) | ||||
|                 } | ||||
|             }) | ||||
|             .collect::<Result<_>>() | ||||
|     } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user