Skip to content

Commit

Permalink
chore: apply suggestions from CR
Browse files Browse the repository at this point in the history
  • Loading branch information
WenyXu committed Aug 20, 2024
1 parent dc8ce28 commit 4a52749
Showing 1 changed file with 24 additions and 45 deletions.
69 changes: 24 additions & 45 deletions src/object-store/src/util.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@
// See the License for the specific language governing permissions and
// limitations under the License.

use std::fmt::Display;

use common_telemetry::{debug, error, trace};
use futures::TryStreamExt;
use opendal::layers::{LoggingInterceptor, LoggingLayer, TracingLayer};
Expand Down Expand Up @@ -149,6 +151,21 @@ pub fn with_instrument_layers(object_store: ObjectStore, path_label: bool) -> Ob

static LOGGING_TARGET: &str = "opendal::services";

struct LoggingContext<'a>(&'a [(&'a str, &'a str)]);

impl<'a> Display for LoggingContext<'a> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
for (i, (k, v)) in self.0.iter().enumerate() {
if i > 0 {
write!(f, " {}={}", k, v)?;
} else {
write!(f, "{}={}", k, v)?;
}
}
Ok(())
}
}

#[derive(Debug, Copy, Clone, Default)]
pub struct DefaultLoggingInterceptor;

Expand All @@ -163,42 +180,22 @@ impl LoggingInterceptor for DefaultLoggingInterceptor {
err: Option<&opendal::Error>,
) {
if let Some(err) = err {
// Print error if it's unexpected, otherwise in debug.
// Print error if it's unexpected, otherwise in warn.
if err.kind() == ErrorKind::Unexpected {
error!(
target: LOGGING_TARGET,
"service={} name={} {}: {operation} {message} {}",
"service={} name={} {}: {operation} {message} {err:#?}",
info.scheme(),
info.name(),
format_args!(
"{}",
context.iter().enumerate().map(|(i, (k, v))| {
if i > 0 {
format!(" {}={}", k, v)
} else {
format!("{}={}", k, v)
}
}).collect::<String>()
),
format!("{err:?}")
LoggingContext(context),
);
} else {
debug!(
target: LOGGING_TARGET,
"service={} name={} {}: {operation} {message} {}",
"service={} name={} {}: {operation} {message} {err}",
info.scheme(),
info.name(),
format_args!(
"{}",
context.iter().enumerate().map(|(i, (k, v))| {
if i > 0 {
format!(" {}={}", k, v)
} else {
format!("{}={}", k, v)
}
}).collect::<String>()
),
format!("{err:?}")
LoggingContext(context),
);
};
}
Expand All @@ -210,33 +207,15 @@ impl LoggingInterceptor for DefaultLoggingInterceptor {
"service={} name={} {}: {operation} {message}",
info.scheme(),
info.name(),
format_args!(
"{}",
context.iter().enumerate().map(|(i, (k, v))| {
if i > 0 {
format!(" {}={}", k, v)
} else {
format!("{}={}", k, v)
}
}).collect::<String>()
),
LoggingContext(context),
);
} else {
trace!(
target: LOGGING_TARGET,
"service={} name={} {}: {operation} {message}",
info.scheme(),
info.name(),
format_args!(
"{}",
context.iter().enumerate().map(|(i, (k, v))| {
if i > 0 {
format!(" {}={}", k, v)
} else {
format!("{}={}", k, v)
}
}).collect::<String>()
),
LoggingContext(context),
);
};
}
Expand Down

0 comments on commit 4a52749

Please sign in to comment.