Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improving Log Analytics by Indexing Cause Messages #436

Open
matiasvigil opened this issue Jul 25, 2024 · 2 comments
Open

Improving Log Analytics by Indexing Cause Messages #436

matiasvigil opened this issue Jul 25, 2024 · 2 comments

Comments

@matiasvigil
Copy link

The cause message in logs is often crucial for understanding what went wrong. However, since it is not indexed, filtering and running analytics on it can be challenging. To address this, the cause message can be added to the log's MDC (Mapped Diagnostic Context) by default. This will make it available as any other MDC field, enabling easier filtering.

Current code

internal class JulLoggerWrapper(override val underlyingLogger: Logger) :
  KLogger, DelegatingKLogger<Logger> {
  override val name: String
    get() = underlyingLogger.name

  override fun at(
    level: io.github.oshai.kotlinlogging.Level,
    marker: Marker?, // marker is not supported in JUL
    block: KLoggingEventBuilder.() -> Unit,
  ) {
    if (isLoggingEnabledFor(level, null)) {
      KLoggingEventBuilder().apply(block).run {
        underlyingLogger.log(level.toJULLevel(), message, cause)
      }
    }
  }

Proposed change

By adding the cause message to the MDC, we can enhance log analytics capabilities. The proposed change is as follows:

internal class JulLoggerWrapper(override val underlyingLogger: Logger) :
  KLogger, DelegatingKLogger<Logger> {
  override val name: String
    get() = underlyingLogger.name

  override fun at(
    level: io.github.oshai.kotlinlogging.Level,
    marker: Marker?, // marker is not supported in JUL
    block: KLoggingEventBuilder.() -> Unit,
  ) {
    if (isLoggingEnabledFor(level, null)) {
      KLoggingEventBuilder().apply(block).run {
        withLoggingContext("causeMessage" to cause?.message) {
          underlyingLogger.log(level.toJULLevel(), message, cause)
        }
      }
    }
  }

Additional Considerations

This change is an example and might need to be applied to other similar logging functions or classes within the codebase to ensure consistency and full coverage. Ensure to review and update all relevant logging points.

Copy link

Thank you for reporting an issue. See the wiki for documentation and slack for questions.

@oshai
Copy link
Owner

oshai commented Dec 3, 2024

Can you please provide more context? Is it something done in other frameworks?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants