From d5da1fa33fdfe2741cda6d0a7dbaecaa87e290f1 Mon Sep 17 00:00:00 2001 From: james58899 Date: Fri, 6 Oct 2023 11:05:26 +0000 Subject: [PATCH] Fix open cache file blocking worker thread --- src/route/cache.rs | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/route/cache.rs b/src/route/cache.rs index cdaa398..f20646a 100644 --- a/src/route/cache.rs +++ b/src/route/cache.rs @@ -60,8 +60,7 @@ async fn hath( if let Some(file) = data .cache_manager .get_file(&info) - .map(|f| async move { NamedFile::open_async(f?).await.ok() }) - .flatten() + .then(|f| async move { tokio::task::spawn_blocking(|| NamedFile::open(f?).ok()).await.ok().flatten() }) .await { let cache_header = CacheControl(vec![CacheDirective::Public, CacheDirective::MaxAge(31536000)]) @@ -184,7 +183,7 @@ async fn hath( builder.insert_header(CacheControl(vec![CacheDirective::Public, CacheDirective::MaxAge(31536000)])); builder.body(SizedStream::new( file_size, - stream! { // TODO bandwidth limit + stream! { let mut file = File::open(temp_path.as_ref()).await.unwrap(); let mut read_off = 0; let mut write_off = *rx.borrow();