Log4j Interview Questions and Answers
Freshers / Beginner level questions & answers
Ques 1. What is Log4j?
Log4j (Log for Java) is logging framework provided by apache foundation for java based applications.
In the applicaitons, if you want to log some information, like any event triggered, or any Database updated is happened, we have the need to log the specific information or error for the useful of the application.
To debug any issues in applications, we have to log the error/exceptions in the logs. For this we will use log4j mechanism.
Log4j logs the information and shows this information in different targets. The different targets are called appenders (console, file etc).
Ques 2. What are the different logging levels?
There are several logging levels that you can configure in you applicaiton.
Ques 3. What is the importance of logging applications?
Logging helps in debugging as well. Although debuggers are available but frankly it takes time to debug an application using a debugger. An application can be debugged more easily with few well-placed logging messages. So we can safely say that logging is a very good debugging tool. If logging is done sensibly and wisely, it can provide detailed context for application failures.
In distributed applications (e.g. web/remote applications), the logging is very important. The administrator can read logs to learn about the problems that occurred during some interval.
Java's built-in APIs provide logging options but they are not that flexible. Another option is to use Apache's open source logging framework called log4j.
Drawbacks of logging applications:
There are some drawbacks of use logging in your application. For example: logging will
- pollute the code
- increase the size of the code
- reduce the speed
These are important points because, we ultimately want efficient applications. Log4J has the solution to this. You may turn on or turn off the logging at runtime by changing the configuration file. This means no change in the Java source code (binary).
Ques 4. Describe about logger levels in log4j.
Before using log4j framework, one should be aware of different categories of log messages. Following are 5 categories:
DEBUG
The DEBUG Level is used to indicate events that are useful to debug an application. Handling method for DEBUG level is: debug().
INFO
INFO level is used to highlight the progress of the application. Handling method for INFO level is: info().
WARN
The WARN level is used to indicate potentially harmful situations. Handling method for WARN level is: warn().
ERROR
The ERROR level shows errors messages that might not be serious enough and allow the application to continue. Handling method for ERROR level is: error().
FATAL
The Fatal level is used to indicate severe events that will may cause abortion of the application. Handling method for FATAL level is: fatal().
If you declare log level as debug in the configuration file, then all the other log messages will also be recorded.
If you declare log level as info in the configuration file, then info, warn, error and fatal log messages will be recorded.
If you declare log level as warn in the configuration file, then warn, error and fatal log messages will be recorded.
If you declare log level as error in the configuration file, then error and fatal log messages will be recorded.
If you declare log level as fatal in the configuration file, then only fatal log messages will be recorded.
Ques 5. What are the three main components in log4j?
There are 3 main components that are used to log messages based upon type and level. These components also control the formatting and report place at runtime. These components are:
- loggers
- appenders
- layouts
Ques 6. Explain why to use Apache Log4j.
- Apache log4j is an open-source and due to this, it's completely free to use.
- You can easily save log information into either files or even databases.
- Can be used for projects of any size small, medium, or large.
Ques 7. What are the features of log4j?
The following are features of log4j:
- Log4j is thread-safe.
- It is optimized for speed.
- It is based on a named logger hierarchy.
- It supports multiple output appenders per logger.
- It supports internationalization.
- It is not restricted to a predefined set of facilities.
- Logging behavior can be set at runtime using a configuration file.
- It is designed to handle Java Exceptions from the start.
- It uses multiple levels, namely ALL, TRACE, DEBUG, INFO, WARN, ERROR, and FATAL.
- The format of the log output can be easily changed by extending the Layout class.
- The target of the log output as well as the writing strategy can be altered by implementations of the Appender interface.
- It is a fail-stop. However, although it certainly strives to ensure delivery, log4j does not guarantee that each log statement will be delivered to its destination.
Ques 8. What are the two static methods for obtaining a logger object?
The two static methods in log4j for obtaining a logger object are:
- public static Logger getRootLogger()
- public static Logger getLogger(String name)
Ques 9. How log4j file is defined?
Log4j file is defined by the name log4j.properties, it keeps properties in key-value pairs. By default, the log manager looks for a file name log4j.properties in the CLASSPATH.
Ques 10. What is package-level logging in log4j?
Package level logging is the standard logging of log4j, with this we would determine the package and the associated level.
Ques 11. What are the Pros and Cons (advantages and disadvantages) of Logging?
Ques 12. What is the purpose of DEBUG log level?
Ques 13. What is the purpose of the ERROR log level?
Ques 14. What is the purpose of the FATAL log level?
Ques 15. What is the purpose of the INFO log level?
Ques 16. What is the purpose of the OFF log level?
Ques 17. What is the purpose of the TRACE log level?
The TRACE log level d
Ques 18. What is the purpose of the WARN log level?
Ques 19. How do Log Levels work or tell the log level hierarchy?
Ques 20. What are different appenders that can configure in log4j?
There are different appenders that we can configure in log4j are: CONSOLE, FILES, DATABASE, JMS, EVENT LOGGING.
Mainly used appenders:
Files in log4j:- Files Appender is used to log the information into our custom name files. when we are configuring this appender, we can specify the file name.
Ques 21. How will you define a root logger turning DEBUG mode off?
# Define the root logger with appender file
log = /usr/home/log4j log4j.rootLogger = WARN, FILE
Most helpful rated by users:
- What is Log4j?
- What are the different logging levels?
- Describe about logger levels in log4j.
- What are the three main components in log4j?
- What is the importance of logging applications?