From 2c656039ddb9eb6830365e98e57bd1e5767c8607 Mon Sep 17 00:00:00 2001 From: Xuanwo Date: Tue, 20 Dec 2022 21:58:47 +0800 Subject: [PATCH] feat: Enable logging for opendal operations Signed-off-by: Xuanwo --- src/cache/azure.rs | 4 +++- src/cache/cache.rs | 3 ++- src/cache/gcs.rs | 5 +++-- src/cache/s3.rs | 4 +++- 4 files changed, 11 insertions(+), 5 deletions(-) diff --git a/src/cache/azure.rs b/src/cache/azure.rs index 6c9a2ba03..8d773301a 100644 --- a/src/cache/azure.rs +++ b/src/cache/azure.rs @@ -15,6 +15,7 @@ use opendal::Operator; +use opendal::layers::LoggingLayer; use opendal::services::azblob; use crate::errors::*; @@ -27,6 +28,7 @@ impl AzureBlobCache { builder.container(container); builder.root(key_prefix); - Ok(builder.build()?.into()) + let op: Operator = builder.build()?.into(); + Ok(op.layer(LoggingLayer::default())) } } diff --git a/src/cache/cache.rs b/src/cache/cache.rs index df833c4a8..4ffd74f54 100644 --- a/src/cache/cache.rs +++ b/src/cache/cache.rs @@ -335,8 +335,9 @@ impl Storage for opendal::Operator { let hit = CacheRead::from(io::Cursor::new(res))?; Ok(Cache::Hit(hit)) } + Err(e) if e.kind() == opendal::ErrorKind::ObjectNotFound => Ok(Cache::Miss), Err(e) => { - warn!("Got error: {:?}", e); + warn!("Got unexpected error: {:?}", e); Ok(Cache::Miss) } } diff --git a/src/cache/gcs.rs b/src/cache/gcs.rs index cd1e48066..c1fa3dc89 100644 --- a/src/cache/gcs.rs +++ b/src/cache/gcs.rs @@ -14,8 +14,8 @@ // limitations under the License. use crate::errors::*; -use opendal::services::gcs; use opendal::Operator; +use opendal::{layers::LoggingLayer, services::gcs}; use reqsign::{GoogleBuilder, GoogleToken, GoogleTokenLoad}; #[derive(Copy, Clone)] @@ -67,7 +67,8 @@ impl GCSCache { } builder.signer(signer_builder.build()?); - Ok(builder.build()?.into()) + let op: Operator = builder.build()?.into(); + Ok(op.layer(LoggingLayer::default())) } } diff --git a/src/cache/s3.rs b/src/cache/s3.rs index d218ecf96..056711979 100644 --- a/src/cache/s3.rs +++ b/src/cache/s3.rs @@ -10,6 +10,7 @@ // See the License for the specific language governing permissions and // limitations under the License. +use opendal::layers::LoggingLayer; use opendal::services::s3; use opendal::Operator; @@ -41,7 +42,8 @@ impl S3Cache { builder.endpoint(&endpoint_resolver(endpoint, use_ssl)?); } - Ok(builder.build()?.into()) + let op: Operator = builder.build()?.into(); + Ok(op.layer(LoggingLayer::default())) } }