Logging in Spring Boot: A Comprehensive Guide
author : Sai K
Logging is a crucial aspect of any application. It helps in debugging, monitoring, and maintaining
                    the application. 
 Spring Boot provides extensive support for logging, making it easy to configure and
                    use. This guide will walk you 
 through setting up and using logging in a Spring Boot 3.2 application.
                
Prerequisites
- JDK 17 or later
- Maven or Gradle
- IDE (IntelliJ IDEA, Eclipse, etc.)
Step 1: Set Up a Spring Boot Project
1.1 Create a New Spring Boot Project
Use Spring Initializr to create a new project with the following dependencies:
- Spring Web
Download and unzip the project, then open it in your IDE.
Step 2: Basic Logging Configuration
Spring Boot uses Logback as the default logging framework. It also supports other logging frameworks
                    such as
 Log4j2  and Java Util Logging.
2.1 Using application.properties for Logging Configuration
In the src/main/resources directory, create or update the application.properties file to configure logging.
# src/main/resources/application.properties
# Logging configuration
logging.level.root=INFO
logging.level.org.springframework.web=DEBUG
logging.file.name=logs/spring-boot-application.log
logging.pattern.console=%d{yyyy-MM-dd HH:mm:ss} - %msg%n
logging.pattern.file=%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n
Explanation:
- logging.level.root=INFO: Sets the root logging level to INFO.
- logging.level.org.springframework.web=DEBUG: Sets the logging level for Spring Web to DEBUG.
- logging.file.name=logs/spring-boot-application.log: Specifies the file name for logging.
- logging.pattern.console: Sets the pattern for console logging.
- logging.pattern.file: Sets the pattern for file logging.
2.2 Using application.yml for Logging Configuration
Alternatively, you can use the aprepplication.yml file for logging configuration.
# src/main/resources/application.yml
logging:
  level:
    root: INFO
    org.springframework.web: DEBUG
  file:
    name: logs/spring-boot-application.log
  pattern:
    console: "%d{yyyy-MM-dd HH:mm:ss} - %msg%n"
    file: "%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n"
Explanation:
The YAML configuration mirrors the properties file configuration but uses YAML syntax.
Step 3: Using Logging in Your Application
3.1 Create a Sample Controller
Create a controller class named HelloController in the com.example.demo.controller package.
package com.example.demo.controller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class HelloController {
    private static final Logger logger = LoggerFactory.getLogger(HelloController.class);
    @GetMapping("/hello")
    public String hello(@RequestParam(required = false, defaultValue = "World") String name) {
        logger.info("Received request to /hello with name: {}", name);
        return "Hello, " + name + "!";
    }
}
Explanation:
- Logger and LoggerFactory: Classes from SLF4J (Simple Logging Facade for Java) to log messages.
- logger.info: Logs an informational message.
- logger.debug, logger.error, etc.: Other logging levels.
Step 4: Advanced Logging Configuration
4.1 Configuring Logback with logback-spring.xml
For more advanced logging configurations, you can use a logback-spring.xml file. Create this file in
                    the 
 src/main/resources directory.
    
< configuration>
    < property name="LOGS" value="logs"/>
    < appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        < file>${LOGS}/spring-boot-application.log< /file>
        < rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            < fileNamePattern>${LOGS}/spring-boot-application-%d{yyyy-MM-dd}.log< /fileNamePattern>
            < maxHistory>30< /maxHistory>
        < /rollingPolicy>
        < encoder>
            < pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n< /pattern>
        < /encoder>
    < /appender>
    < appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        < encoder>
            < pattern>%d{yyyy-MM-dd HH:mm:ss} - %msg%n< /pattern>
        < /encoder>
    < /appender>
    < logger name="org.springframework.web" level="DEBUG"/>
    < root level="INFO">
        < appender-ref ref="FILE"/>
        < appender-ref ref="CONSOLE"/>
    < /root>
< /configuration>
Explanation:
- RollingFileAppender: Logs messages to a file with rolling based on time.
- ConsoleAppender: Logs messages to the console.
- logger and root: Configures logging levels and appenders.
4.2 Using Log4j2
If you prefer Log4j2, include the necessary dependencies in your pom.xml file and configure log4j2-spring.xml.
Adding Log4j2 Dependencies
    < dependency>
        < groupId>org.springframework.boot< /groupId>
        < artifactId>spring-boot-starter-log4j2< /artifactId>
    < /dependency>
Creating log4j2-spring.xml
Create log4j2-spring.xml in the src/main/resources directory.
    < ?xml version="1.0" encoding="UTF-8"?>
< Configuration status="WARN">
    < Appenders>
        < Console name="Console" target="SYSTEM_OUT">
            < PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n"/>
        < /Console>
        < RollingFile name="File" fileName="logs/spring-boot-application.log" filePattern="logs/spring-boot-application-%d{yyyy-MM-dd}.log">
            < PatternLayout>
                < pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n< /pattern>
            < /PatternLayout>
            < TimeBasedTriggeringPolicy/>
            < DefaultRolloverStrategy max="30"/>
        < /RollingFile>
    < /Appenders>
    < Loggers>
        < Root level="info">
            < AppenderRef ref="Console"/>
            < AppenderRef ref="File"/>
        < /Root>
        < Logger name="org.springframework.web" level="debug" additivity="false">
            < AppenderRef ref="Console"/>
            < AppenderRef ref="File"/>
        < /Logger>
    < /Loggers>
< /Configuration>
Explanation:
- Configuration: Defines the configuration for Log4j2.
- Appenders: Defines where the log messages will be sent (console and file).
- Loggers: Defines logging levels and the appenders for different packages.
Step 5: Running and Testing the Application
5.1 Run the Application
Run the Spring Boot application using your IDE or the command line:
./mvnw spring-boot:run5.2 Test Logging
Use a web browser or a tool like Postman to send a GET request to
                    http://localhost:8080/hello? 
name=SpringBoot. Check the console and log files to see the logging
                    messages.
Conclusion
In this comprehensive guide, you have learned how to set up and use logging in a Spring Boot 3.2
                    application.  
We covered:
- Basic logging configuration using application.properties and application.yml.
- Using SLF4J for logging in your application.
- Advanced logging configuration using logback-spring.xml.
- Configuring and using Log4j2.
By following these steps, you can effectively configure and manage logging in your Spring Boot
                    applications to 
 help with debugging, monitoring, and maintaining your application.