Apache logging services logo Apache log4j logo

Log4j 1.2 Bridge

The Log4j 1.2 Bridge allows applications coded to use Log4j 1.2 API to use Log4j 2 instead.

Requirements

The Log4j 1.2 bridge is dependent on the Log4j 2 API. The following Log4j 1.x methods will behave differently when the Log4j 2 Core module is included then when it is not:

Method Without log4j-core With log4j-core
Category.getParent() Returns null Returns parent logger
Category.setLevel() NoOp Sets Logger Level
Category.setPriority() NoOp Sets Logger Level
Category.getAdditivity() Returns false Returns Logger’s additivity setting
Category.setAdditivity() NoOp Sets additivity of LoggerConfig
Category.getResourceBundle() NoOp Returns the resource bundle associated with the Logger
BasicConfigurator.configure() NoOp Reconfigures Log4j 2

If log4j-core is not present location information will not be accurate in calls using the Log4j 1.2 API. The config package which attempts tp convert Log4j 1.x configurations to Log4j 2 is not supported without Log4j 2.

For more information, see Runtime Dependencies.

Usage

To use the Log4j Legacy Bridge just remove all the Log4j 1.x jars from the application and replace them with the bridge jar. Once in place all logging that uses Log4j 1.x will be routed to Log4j 2. However, applications that attempt to modify legacy Log4j by adding Appenders, Filters, etc may experience problems if they try to verify the success of these actions as these methods are largely no-ops.