mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	Merge #4435
4435: Make update file deletion atomic r=Kerollmops a=irevoire # Pull Request ## Related issue Fixes https://github.com/meilisearch/meilisearch/issues/4432 Fixes https://github.com/meilisearch/meilisearch/issues/4438 by adding the logs the user asked ## What does this PR do? - Adds a bunch of logs to help debug this kind of issue in the future - Delete the update files AFTER committing the update in the `index-scheduler` (thus, if a restart happens, we are able to re-process the batch successfully) - Multi-thread the deletion of all update files. Co-authored-by: Tamo <tamo@meilisearch.com>
This commit is contained in:
		| @@ -61,7 +61,13 @@ impl FileStore { | ||||
|     /// Returns the file corresponding to the requested uuid. | ||||
|     pub fn get_update(&self, uuid: Uuid) -> Result<StdFile> { | ||||
|         let path = self.get_update_path(uuid); | ||||
|         let file = StdFile::open(path)?; | ||||
|         let file = match StdFile::open(path) { | ||||
|             Ok(file) => file, | ||||
|             Err(e) => { | ||||
|                 tracing::error!("Can't access update file {uuid}: {e}"); | ||||
|                 return Err(e.into()); | ||||
|             } | ||||
|         }; | ||||
|         Ok(file) | ||||
|     } | ||||
|  | ||||
| @@ -96,8 +102,12 @@ impl FileStore { | ||||
|  | ||||
|     pub fn delete(&self, uuid: Uuid) -> Result<()> { | ||||
|         let path = self.path.join(uuid.to_string()); | ||||
|         std::fs::remove_file(path)?; | ||||
|         Ok(()) | ||||
|         if let Err(e) = std::fs::remove_file(path) { | ||||
|             tracing::error!("Can't delete file {uuid}: {e}"); | ||||
|             Err(e.into()) | ||||
|         } else { | ||||
|             Ok(()) | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /// List the Uuids of the files in the FileStore | ||||
|   | ||||
		Reference in New Issue
	
	Block a user