mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Use a buffered sync channel to avoid blocking the update system
This commit is contained in:
		| @@ -84,7 +84,7 @@ struct Document(indexmap::IndexMap<String, String>); | |||||||
| fn index_command(command: IndexCommand, database: Database) -> Result<(), Box<dyn Error>> { | fn index_command(command: IndexCommand, database: Database) -> Result<(), Box<dyn Error>> { | ||||||
|     let start = Instant::now(); |     let start = Instant::now(); | ||||||
|  |  | ||||||
|     let (sender, receiver) = mpsc::sync_channel(0); |     let (sender, receiver) = mpsc::sync_channel(100); | ||||||
|     let update_fn = move |update: UpdateResult| sender.send(update.update_id).unwrap(); |     let update_fn = move |update: UpdateResult| sender.send(update.update_id).unwrap(); | ||||||
|     let index = database.open_index(INDEX_NAME, Some(Box::new(update_fn)))?; |     let index = database.open_index(INDEX_NAME, Some(Box::new(update_fn)))?; | ||||||
|     let rkv = database.rkv.read().unwrap(); |     let rkv = database.rkv.read().unwrap(); | ||||||
| @@ -144,6 +144,7 @@ fn index_command(command: IndexCommand, database: Database) -> Result<(), Box<dy | |||||||
|         println!("committing update..."); |         println!("committing update..."); | ||||||
|         let update_id = additions.finalize(writer)?; |         let update_id = additions.finalize(writer)?; | ||||||
|         max_update_id = max_update_id.max(update_id); |         max_update_id = max_update_id.max(update_id); | ||||||
|  |         println!("committed update {}", update_id); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     println!("Waiting for update {}", max_update_id); |     println!("Waiting for update {}", max_update_id); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user