Over a million developers have joined DZone.
{{announcement.body}}
{{announcement.title}}

Java Logging Frameworks and Tools

DZone's Guide to

Java Logging Frameworks and Tools

In this post, we take a look at some of the most common and well-known logging frameworks available in Java to see what you should consider for your projects.

· Java Zone
Free Resource

Just released, a free O’Reilly book on Reactive Microsystems: The Evolution of Microservices at Scale. Brought to you in partnership with Lightbend.

Logging information in your application is critical to the understanding of the runtime behavior of any application, especially in cases when you encounter unexpected scenarios, errors, or just for tracking certain activities.

As more and more companies move to the cloud, log analysis and log management tools and services are becoming more critical. Some tools, such as Loggly, Logstash, Graylog, etc., help you to analyze and monitor logs.

Overall, logging is certainly a fundamental practice that provides significant benefits during the lifetime of an application.

Let’s look at some Java logging frameworks and tools.

Apache Log4j 2

Apache Log4j 2 is an upgrade to Log4j that provides many of the improvements available in Logback while fixing some inherent problems in Logback’s architecture. It provides asynchronous logging, which significantly improves performance, especially in multi-threaded applications.

We can include the Maven dependency as follows:

<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.9.1</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.9.1</version>
</dependency>


Logback

Logback is an improved version of log4j. It is conceptually like log4j, as both projects were founded by the same developer. If you are already familiar with log4j, you can pick up Logback quickly.

Visit the official site to know about all of its benefits.

Include the Maven dependency as follows:

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.2.3</version>
</dependency>


tinylog

tinylog is a logging framework for Java and Android. The logger is static, so it is not necessary to create an instance of the logger before logging.

We can include the Maven dependency as follows:

<dependency>
    <groupId>org.tinylog</groupId>
    <artifactId>tinylog</artifactId>
    <version>1.2</version>
</dependency>


Logbook

Logbook is a Java library to enable complete request and response logging for various client and server-side technologies. It provides support for Servlet containers, Apache’s HTTP client, and other frameworks. It also has auto-configuration for Spring Boot.

We can selectively add the dependencies to the project:

<dependency>
    <groupId>org.zalando</groupId>
    <artifactId>logbook-core</artifactId>
    <version>1.4.0</version>
</dependency>
<dependency>
    <groupId>org.zalando</groupId>
    <artifactId>logbook-servlet</artifactId>
    <version>1.4.0</version>
</dependency>
<dependency>
    <groupId>org.zalando</groupId>
    <artifactId>logbook-httpclient</artifactId>
    <version>1.4.0</version>
</dependency>
<dependency>
    <groupId>org.zalando</groupId>
    <artifactId>logbook-spring-boot-starter</artifactId>
    <version>1.4.0</version>
</dependency>


Conclusion

Logging is very important in application development due to the highly useful and actionable insights it brings during the runtime of an application. Choose the framework as per your project needs and log wisely!

Strategies and techniques for building scalable and resilient microservices to refactor a monolithic application step-by-step, a free O'Reilly book. Brought to you in partnership with Lightbend.

Topics:
java ,logging frameworks ,log4j2 ,logback ,tinylog ,logbook ,tutorial

Published at DZone with permission of Swathi Prasad, DZone MVB. See the original article here.

Opinions expressed by DZone contributors are their own.

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}