Skip to content

Numichi/reactive-logger

Folders and files

NameName
Last commit message
Last commit date
Jan 22, 2022
Jan 16, 2022
May 22, 2022
Jan 16, 2022
Aug 8, 2020
Feb 16, 2022
May 22, 2022
May 22, 2022
Jan 16, 2022
Jan 16, 2022
Jan 22, 2022

Repository files navigation

reactive-logger

CircleCI Maintainability Test Coverage Apache-2.0 Maven Central Tested on Reactor Project

After releases, SonaType or mvnrepostiroy may not appear. Regardless, the package is available.

Important

This is just a hobby project driven by self motivation. There is no external sponsor behind the project.

What is the source of motivation?

I think this description approaches the What Is a Good Pattern for Contextual Logging? (MDC) well. Furthermore, there is the so-called lifting solution, which I think is overkill. In this (lifting) example, he uses Kotlin, but with a Reactor API, not a coroutine. If you stay with Reactor API, there is no problem with lifting and it work. I mean, I didn't experience any pain, regardless of I used Kotlin or Java. But it is not valid for Kotlin Coroutine.

My first problem with the lifting solution. It runs a hook for each reactor API. It generates a lot of unnecessary events and class creation. I have tested it with a minimal controller with Spring Boot (see: GET /counter). MDC map copy had run about 129 times for only one request. Then let's count how many times will run on one of the more complex applications?

My second problem on Kotlin Coroutine with lifting. It does not work. When you call a Reactor API, API will activate hook, and MDC ThreadLocal will be overridden. After it, coroutine gets run point back. Hooks are not taken effect in coroutine areas. If you would like to run a logger with slf4j in the coroutine area, according to slf4j, the MDC is empty, but CoroutineContext is not.

Another side effect I have experienced. When I created a parallel request, my first request ended later than my second request. I have used a suspended delay in code, and I noticed the following: MDC context data slipping to another request. I think it is unhealthy and misinforms when you review logs.

Goal: So, I have been working to create an API for Reactor and Coroutine what solve the above problems. It provides the same interfaces to both environments and follows Reactor MDC documentation.

Overview

Part of the documentation and description comes from: README.md

reactive-logger is a Java and Kotlin library adapting the slf4j logging library for reactive applications. It treats the various message-writing methods in the slf4j Logger interface as blocking I/O by wrapping each to the reactive environment that invokes the method on a scheduler appropriate for blocking I/O.

The library has many goals:

  • Provide reactive code with a familiar and natural logging interface analogous to the slf4j Logger interface in imperative code.
  • Facilitate a novel approach to the three-way trade-off between reliability, performance, and resource consumption that application logs commonly face.
  • Obey the rule restricting blocking I/O to bounded elastic schedulers without requiring a specific logging configuration to do so.
  • Provide the appropriate language approach for Java Reactor or Kotlin Coroutine code.

Documentation

Dependency

Maven

<dependency>
  <groupId>io.github.numichi</groupId>
  <artifactId>reactive-logger</artifactId>
  <version>VERSION</version>
</dependency>

Gradle Groovy DSL

implementation 'io.github.numichi:reactive-logger:VERSION'

Gradle Kotlin DSL

implementation("io.github.numichi:reactive-logger:VERSION")

About

A Java & Kotlin library adapting slf4j for reactive applications

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Kotlin 95.2%
  • Java 4.8%