src/backup/catalog.rs - SenderWriter: use tokio::task::block_in_place
Make sure we do not block the executor.
This commit is contained in:
		| @ -384,11 +384,13 @@ impl SenderWriter { | |||||||
|  |  | ||||||
| impl Write for SenderWriter { | impl Write for SenderWriter { | ||||||
|     fn write(&mut self, buf: &[u8]) -> Result<usize, std::io::Error> { |     fn write(&mut self, buf: &[u8]) -> Result<usize, std::io::Error> { | ||||||
|  |         tokio::task::block_in_place(|| { | ||||||
|             futures::executor::block_on(async move { |             futures::executor::block_on(async move { | ||||||
|                 self.0.send(Ok(buf.to_vec())).await |                 self.0.send(Ok(buf.to_vec())).await | ||||||
|                     .map_err(|err| std::io::Error::new(std::io::ErrorKind::Other, err.to_string()))?; |                     .map_err(|err| std::io::Error::new(std::io::ErrorKind::Other, err.to_string()))?; | ||||||
|                 Ok(buf.len()) |                 Ok(buf.len()) | ||||||
|             }) |             }) | ||||||
|  |         }) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     fn flush(&mut self) -> Result<(), std::io::Error> { |     fn flush(&mut self) -> Result<(), std::io::Error> { | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user